

## TX32M2300 数据手册



|      |            |                |       |                |
|------|------------|----------------|-------|----------------|
| 保密等级 | A          | TX32M2300 数据手册 | 文件 编号 | TX-TX8C1260-RD |
| 发行日期 | 2023-04-11 |                | 文件 版本 | V2.2           |

## 修订记录

| 日期         | 版本   | 描述                       |
|------------|------|--------------------------|
| 2023-04-11 | V2.2 | 1、修改比较器部分关于正端和负端输入的选择描述； |
| 2023-02-03 | V2.1 | 1、解决部分设备打开阅读时，出现乱码问题；    |
| 2022-08-12 | V2.0 | 1、重新整理了文档的格式；            |

### 注意：

- 本公司保留对以下所有产品在功能、性能、方案、设计及改进方面的最终解释权。
- 本公司保留对文档复制及更改的权利。

## 目录

|                                   |    |
|-----------------------------------|----|
| TX32M2300 数据手册 .....              | 1  |
| 1. 总介 .....                       | 1  |
| 1. 1. 概述 .....                    | 1  |
| 1. 2. 产品特性 .....                  | 1  |
| 2. 系统及存储器架构 .....                 | 4  |
| 2. 1. 32 位 RISC 处理器 .....         | 5  |
| 2. 2. 系统架构 .....                  | 5  |
| 2. 3. 存储器映射 .....                 | 7  |
| 2. 3. 1. 位带操作 .....               | 8  |
| 2. 3. 2. 片上 SRAM 存储器 .....        | 9  |
| 2. 3. 3. 片上 FLASH 存储器概述 .....     | 9  |
| 2. 3. 4. 引导配置 .....               | 10 |
| 2. 4. MCLR 功能 .....               | 10 |
| 3. 嵌入式闪存 .....                    | 10 |
| 3. 1. 闪存主要特性 .....                | 10 |
| 3. 2. 闪存功能描述 .....                | 10 |
| 3. 2. 1. 闪存结构 .....               | 10 |
| 3. 2. 2. 闪存读保护 .....              | 11 |
| 3. 2. 3. 闪存烧写和擦除操作 .....          | 12 |
| 3. 3. 寄存器 .....                   | 12 |
| 3. 3. 1. 寄存器基地址 .....             | 12 |
| 3. 3. 2. 寄存器列表 .....              | 12 |
| 3. 3. 3. 寄存器详细说明 .....            | 13 |
| 4. 中断和事件 .....                    | 19 |
| 4. 1. 嵌套向量中断控制器 .....             | 19 |
| 4. 2. 系统嘀嗒 (SysTick) 校准值寄存器 ..... | 19 |
| 4. 3. 中断功能描述 .....                | 19 |
| 4. 4. 外部中断/事件控制器 (EXTI) .....     | 21 |
| 4. 4. 1. 主要特征 .....               | 21 |
| 4. 4. 2. 唤醒事件管理 .....             | 22 |
| 5. CRC 计算单元 .....                 | 98 |
| 5. 1. 主要特性 .....                  | 98 |
| 5. 2. 寄存器 .....                   | 99 |
| 5. 2. 1. 寄存器基地址 .....             | 99 |
| 5. 2. 2. 寄存器列表 .....              | 99 |

|                                     |     |
|-------------------------------------|-----|
| 5.2.3. 寄存器详细说明.....                 | 99  |
| 5.3. 操作流程.....                      | 101 |
| 6. 电源控制 (power control) .....       | 22  |
| 6.1. 电源.....                        | 22  |
| 6.1.1. 电压调节器.....                   | 22  |
| 6.2. 电源管理器.....                     | 23  |
| 6.2.1. 上电复位 (POR) 和掉电复位 (PDR) ..... | 23  |
| 6.2.2. 可编程电压监测器 (PVD) .....         | 23  |
| 6.3. 低功耗模式.....                     | 24  |
| 6.4. 寄存器.....                       | 25  |
| 6.4.1. 寄存器基址.....                   | 25  |
| 6.4.2. 寄存器列表.....                   | 25  |
| 6.4.3. 寄存器详细说明.....                 | 25  |
| 7. 复位和时钟控制.....                     | 27  |
| 7.1. 复位.....                        | 27  |
| 7.1.1. 系统复位.....                    | 27  |
| 7.2. 主复位.....                       | 27  |
| 7.2.1. 电源复位.....                    | 27  |
| 7.3. 时钟.....                        | 28  |
| 7.3.1. XOSC 时钟.....                 | 28  |
| 7.3.2. HIRC 时钟.....                 | 28  |
| 7.3.3. PLL.....                     | 28  |
| 7.3.4. LIRC 时钟.....                 | 28  |
| 7.3.5. 系统时钟 (SYSCLK) 选择.....        | 29  |
| 7.3.6. DBSCLK 选择.....               | 29  |
| 7.3.7. LVDDBS_CLK 时钟选择.....         | 29  |
| 7.3.8. CMPCLK 时钟选择.....             | 30  |
| 7.3.9. 时钟安全系统 (CSS) .....           | 31  |
| 7.4. 寄存器.....                       | 31  |
| 7.4.1. 寄存器基址.....                   | 31  |
| 7.4.2. 寄存器列表.....                   | 31  |
| 7.4.3. 寄存器定义.....                   | 32  |
| 8. GPIO.....                        | 50  |
| 8.1. GPIO 主要特征.....                 | 50  |
| 8.2. GPIO 功能描述.....                 | 50  |
| 8.2.1. 通用 IO (GPIO) .....           | 51  |
| 8.2.2. 单独的位操作.....                  | 52  |
| 8.2.3. 复用功能 (AF) .....              | 52  |
| 8.2.4. GPIO 锁定机制.....               | 52  |

|                        |     |
|------------------------|-----|
| 8.2.5. 输入配置.....       | 52  |
| 8.2.6. 输出配置.....       | 53  |
| 8.2.7. 模拟输入配置.....     | 53  |
| 8.3. 寄存器.....          | 54  |
| 8.3.1. 寄存器基地址.....     | 54  |
| 8.3.2. 寄存器列表.....      | 54  |
| 8.3.3. 寄存器详细定义.....    | 55  |
| 9. 通信接口外设 CSI.....     | 72  |
| 9.1. SPI_I2C.....      | 72  |
| 9.1.1. SPI 功能描述.....   | 72  |
| 9.1.2. I2C 功能描述.....   | 73  |
| 9.1.3. SPI 时序图.....    | 73  |
| 9.1.4. IO MAPPING..... | 75  |
| 9.2. 寄存器.....          | 75  |
| 9.2.1. 寄存器基地址.....     | 75  |
| 9.2.2. 寄存器列表.....      | 75  |
| 9.2.3. 寄存器详细说明.....    | 76  |
| 9.2.4. 使用说明.....       | 82  |
| 10. UART.....          | 87  |
| 10.1. 概述.....          | 87  |
| 10.2. 寄存器.....         | 88  |
| 10.2.1. 寄存器基地址.....    | 88  |
| 10.2.2. 寄存器列表.....     | 88  |
| 10.2.3. 寄存器详细说明.....   | 89  |
| 10.2.4. 使用说明.....      | 96  |
| 11. 硬件加速单元.....        | 102 |
| 11.1. 加速单元简介.....      | 102 |
| 11.2. 硬件除法主要特征.....    | 102 |
| 11.3. 硬件除法功能介绍.....    | 102 |
| 11.4. 寄存器.....         | 102 |
| 11.4.1. 寄存器基地址.....    | 102 |
| 11.4.2. 寄存器列表.....     | 103 |
| 11.4.3. 寄存器详细说明.....   | 103 |
| 12. 比较器 (COMP) .....   | 104 |
| 12.1. 简介.....          | 104 |
| 12.2. 主要特性.....        | 104 |
| 12.3. 功能描述.....        | 105 |
| 12.3.1. 比较器功能框图.....   | 105 |

|                          |     |
|--------------------------|-----|
| 12.3.2. 比较器输入和输出.....    | 106 |
| 12.3.3. 比较器工作模式.....     | 106 |
| 12.3.4. 比较器滤波控制.....     | 107 |
| 12.3.5. 比较器轮询周期.....     | 107 |
| 12.3.6. 比较器中断和唤醒.....    | 108 |
| 12.3.7. 比较器锁定机制.....     | 108 |
| 12.3.8. 比较器迟滞现象.....     | 108 |
| 12.4. 寄存器.....           | 108 |
| 12.4.1. 寄存器基址.....       | 108 |
| 12.4.2. 寄存器列表.....       | 109 |
| 12.4.3. 寄存器详细说明.....     | 109 |
| 13. 运算放大器 (OPA) .....    | 113 |
| 13.1. 简介.....            | 113 |
| 13.2. 主要特征.....          | 113 |
| 13.3. 寄存器描.....          | 113 |
| 13.3.1. 寄存器基址.....       | 113 |
| 13.3.2. 寄存器列表.....       | 113 |
| 13.3.3. 寄存器详细说明.....     | 114 |
| 14. ADC.....             | 116 |
| 14.1. 功能简介.....          | 116 |
| 14.2. 主要特征.....          | 116 |
| 14.3. 结构框图.....          | 117 |
| 14.4. 功能描述.....          | 118 |
| 14.4.1. ADC 开关控制.....    | 118 |
| 14.4.2. 通道选择.....        | 118 |
| 14.4.3. ADC 工作模式.....    | 118 |
| 14.4.4. DMA 请求.....      | 119 |
| 14.4.5. 采样频率设置.....      | 119 |
| 14.4.6. 连续采样间隔时间可配置..... | 119 |
| 14.4.7. 外部触发转换.....      | 120 |
| 14.5. ADC 接口时序.....      | 120 |
| 14.5.1. ADC 上电时序.....    | 120 |
| 14.6. 寄存器.....           | 121 |
| 14.6.1. 寄存器基址.....       | 121 |
| 14.6.2. 寄存器列表.....       | 121 |
| 14.6.3. 寄存器详细说明.....     | 122 |
| -.....                   | 123 |
| 15. Timer.....           | 131 |
| 15.1. 简介.....            | 131 |

|                                                      |     |
|------------------------------------------------------|-----|
| 15.2. 主要特性.....                                      | 131 |
| 15.3. 功能描述.....                                      | 132 |
| 15.3.1. 时基单元.....                                    | 132 |
| 15.3.2. 计数源选择.....                                   | 133 |
| 15.3.3. 输入捕获源.....                                   | 133 |
| 15.3.4. 输入捕获模式.....                                  | 134 |
| 15.3.5. PWM 模式.....                                  | 135 |
| 15.3.6. 触发 ADC 采样.....                               | 136 |
| 15.3.7. timer 同步输出.....                              | 136 |
| 15.3.8. 从模式.....                                     | 137 |
| 15.3.9. 复位模式.....                                    | 137 |
| 15.3.10. 触发模式.....                                   | 137 |
| 15.3.11. 门控模式.....                                   | 138 |
| 15.3.12. DMA 传输模式.....                               | 138 |
| 15.3.13. 多个 timer 之间级联.....                          | 139 |
| 15.3.14. 多个 timer 计数值同时清零.....                       | 139 |
| 15.3.15. 产生带载波的 PWM 信号.....                          | 140 |
| 15.4. 寄存器.....                                       | 140 |
| 15.4.1. 寄存器基地址.....                                  | 140 |
| 15.4.2. 寄存器列表.....                                   | 141 |
| 15.4.3. 寄存器详细说明.....                                 | 141 |
| 16. EPWM.....                                        | 146 |
| 16.1. 简介.....                                        | 146 |
| 16.2. 子模块介绍.....                                     | 147 |
| 16.2.1. 时基计数器子模块 (Time-base) .....                   | 147 |
| 16.2.2. 时基计数比较器子模块 (Counter-comparator) .....        | 148 |
| 16.2.3. 动作产生子模块 (Action-qualifier) .....             | 148 |
| 16.2.4. 死区产生子模块 (Dead-band) .....                    | 149 |
| 16.2.5. 事件触发子模块 (Event-trigger) .....                | 149 |
| 16.2.6. 故障区子模块 (Trip-zone) .....                     | 150 |
| 16.3. 功能描述及常用拓扑.....                                 | 150 |
| 16.3.1. 独立频率控制多个 Buck 转换电路.....                      | 151 |
| 16.3.2. 相同频率控制多个 Buck 转换电路.....                      | 153 |
| 16.3.3. 控制多个 H 半桥电路 (HHB) 转换电路.....                  | 155 |
| 16.3.4. 控制电机的双三相逆变器 (ACI 和 PMSM) .....               | 156 |
| 16.3.5. PWM 模块间相位控制的实际应用.....                        | 158 |
| 16.3.6. 控制三相交错 DC/DC 交换电路.....                       | 160 |
| 16.3.7. 控制 0 电压转换的全桥转换电路 (ZVSFB) .....               | 162 |
| 16.3.8. 控制峰值电流模式 (Peak Current Mode) 控制 Buck 模块..... | 163 |
| 16.3.9. 控制 H 桥 LLC 谐振变换器.....                        | 164 |
| 16.4. 寄存器.....                                       | 165 |

|                      |     |
|----------------------|-----|
| 16.4.1. 寄存器基地址.....  | 165 |
| 16.4.2. 寄存器列表.....   | 166 |
| 16.4.3. 寄存器详细说明..... | 167 |
| 17. WDT.....         | 188 |
| 17.1. 简介.....        | 188 |
| 17.2. 寄存器.....       | 189 |
| 17.2.1. 寄存器基地址.....  | 189 |
| 17.2.2. 寄存器列表.....   | 189 |
| 17.2.3. 寄存器详细说明..... | 189 |

# 1. 总介

## 1.1. 概述

本产品使用高性能的 32 位微控制器，最高工作频率可达 72MHz，内置 32KB 高速 Flash 存储器，6KB SRAM，丰富的增强型 I/O 端口和外设连接到外部总线。本产品包含 1 个 12 位的 ADC、一个 8 位精度 DAC、一个多功能比较器、3 个运算放大器、1 个 16 位高级定时器、5 个 16 位通用定时器、1 个 32 位通用定时器、1 个看门狗定时器、1 个系统滴答定时器。还包含标准的通信接口：2 个 SPI/IIC 接口和 2 个 UART 接口，其中 UART0 可以实现从任意一条 pin 里面选择一条进行代码升级，内置一个 32 位除 16 位有无符号除法器。

本产品产品系列工作电压为 2.0V~5.5V，工作温度范围-40°C ~ 105°C。多种省电工作模式保证低功耗应用的要求。

本产品提供 4 种封装，包括 LQFP32、SSOP28、SSOP24 和 TSSOP20。根据不同的封装形式，器件中的外设配置不尽相同。

下面给出了该系列产品中所有外设的基本介绍。

这些丰富的外设配置，使得本产品微控制器适合于多种应用场合：

- 风机，风扇等
- 消费类电子
- 智能家居
- 电机驱动和应用控制
- 医疗和手持设备
- 工业控制
- 工业应用：可编程控制器（PLC）、变频器、打印机和扫描仪

## 1.2. 产品特性

### ➤ 内核与系统

- 32-Bit RISC 架构的CPU
- 工作最大主频: 72MHz
- 单周期 32 位乘法指令
- 32 个中断源, 可配置 4 层中断优先级, 支持中断入口地址Remap
- 支持位带操作
- 支持双pin调试接口

## ➤ 存储器

- 32K Byte的闪存程序存储器(NO EEPROM Flash), Sector擦写次数 20000 次
- 内部 6K Byte SRAM
- Boot Loader 支持片内 Flash、支持单/双pin UART 在线用户编程 (IAP) / 在线系统编程 (ISP)

## ➤ 时钟、复位和电源管理

- 2V ~ 5.5V 供电
- 上电/断电复位 (POR/PDR)、可编程电压监测器 (PWD)
- 外部 1-32MHz晶体振荡器
- 内嵌经出厂调校的 26MHz (+/- 1.5%) 高速振荡器
- 内嵌 128KHz低速振荡器
- PLL输出 72MHz时钟
- 内置时钟安全系统 (CSS)
- WDT复位

## ➤ DMA 支持

- 支持的外设: EFLASH、UART、SPI/I2C、CRC、TIMER、ADC

## ➤ GPIO

- 最多能支持 30 个GPIO
- 所有 I/O 口可以触发边沿或电平响应中断, 唤醒低功耗模式
- 所有端口均可输入输出 5V 信号
- 支持按键检测

## ➤ 通讯接口外设

- 2 个 SPI 高速串行接口，Master 下最高支持系统时钟频率一半传输，支持 1/2/4 线主从模式，支持 I2C 模式
- 2 个 UART 接口，支持 RS232/RS485 协议，UART0 能支持任意 IO 程序升级

## ➤ 定时器

- 1 个 16 位高级定时器，支持 4 对互补输出或 8 个独立 PWM 输出，支持死区插入和事件刹车功能，支持单脉冲模式
- 5 个 16 位通用定时器，1 个 32 位定时器，每个定时器支持捕获功能
- 1 个看门狗定时器
- 1 个系统滴答定时器

## ➤ 硬件加速单元

- 硬件有符号除法器（32bit/16bit）

## ➤ 高安全性

- 支持 5/7/8/16/32 bit CRC 效验，保证数据准确性
- 支持代码加扰以及硬件加解密

## ➤ 低功耗

- 支持 IDLE、STOP、SLEEP 低功耗模式
- 静态功耗 < 20uA@25°C
- 低功耗唤醒时间最快 10us

## ➤ 1 个 12 位高速模数转换器

- 支持最高 1.2Mhz 采样率
- 多达 10 输入通道

## ➤ 1 个比较器

- 支持 7 个正端输入，3 个负端输入
- 支持硬件通道轮询

## ➤ 3 个运算放大器

- 同向放大器

- 内置 4/6/8/10/12 倍增益可配
- 闭环增益带宽可选
- **内置温度传感器**
- **高可靠性**
  - ESD HBM 8KV
  - EFT ±4500V
  - Latch-up ±100mA @105°C
- **96 位的芯片唯一 ID (UID)**
- **封装**
  - Die Form
  - LQFP32/SSOP28/SSOP24/TSSOP20
- **工业级温度范围**
  - -40°C ~ 105°C
- **应用**
  - 风机等
  - 电机驱动和应用控制
  - 医疗和手持设备
  - PC 游戏外设和 GPS 平台
  - 工业应用：可编程控制器（PLC）、变频器、打印机和扫描仪
  - 警报系统、视频对讲、和暖气通风空调系统等

## 2. 系统及存储器架构

TX32M2300 系列器件是基于 RISC 处理器的 32 位通用微控制器存储器的组织采用了哈佛结构，预先定义的存储器映射和高达 4 GB 的存储空间，充分保证了系统的灵活性和可扩展性。

## 2.1. 32 位 RISC 处理器

TX32M2300 系列所用的 32 位 RISC 处理器是一个具有低中断延迟时间和低成本调试特性的 32 位处理器。高集成度和增强的特性使这颗 RISC 处理器适合于那些需要高性能和低功耗微控制器的市场领域。

## 2.2. 系统架构

TX32M2300 系列器件采用 32 位多层总线结构，该结构可使系统中的多个主机和从机之间的并行通信成为可能。多层次总线结构包括一个 AHB 互联矩阵、两个 AHB 总线和两个 APB 总线。AHB 互联矩阵的互联关系接下来将进行说明。在系统主从互联矩阵的互联关系列表中，“1”表示相应的主机可以通过 AHB 互联矩阵访问对应的从机，空白的单元格表示相应的主机不可以通过 AHB 互联矩阵访问对应的从机。

TX32M2300 系列主系统由以下部分构成：

- 二个驱动单元：
  - CPU 内核系统总线 (S-bus)
  - DMA controller
- 三个被动单元
  - 内部闪存存储器
  - 内部 SRAM
  - AHB 到 APB 的桥 (AHB2APB0/1)，它连接所有的 APB 设备



图 2-1 TX32M2300 系列总线系统架构图

### 系统总线

此总线连接 CPU 内核的系统总线（外设总线）到总线矩阵，总线矩阵协调着内核和各个高速部件间的访问。

#### DMA controller

此总线将 CPU 与各外设模块访问相联竞争，协调访问优先级，仲裁等。

表 2-1 DMA 模块使用的优先级排布

| 模块    | 优先级 | 说明 |
|-------|-----|----|
| CPU   | 0   | 最高 |
| SPI0  | 1   |    |
| SPI1  | 2   |    |
| UART0 | 3   |    |
| ADC   | 4   |    |
| UART1 | 5   |    |
| CRC   | 6   |    |

|        |   |    |
|--------|---|----|
| TIMER5 | 7 |    |
| Eflash | 8 | 最低 |

### 总线矩阵 (BusMatrix)

总线矩阵管理着内核系统总线与各外设模块的访问仲裁，总线矩阵由主模块总线及从模块总线组成。AHB 外设通过总线矩阵与系统总线相连。

#### AHB 到 APB 桥 (AHB2APB bridges-APB)

AHB 到 APB 桥在 AHB 与 APB 总线间提供同步连接。

注：当对 APB 寄存器进行 8 位或者 16 位访问时，该访问会被自动转换成 32 位的访问：桥会自动将 16 位或者 8 位的数据扩展以配合 32 位的宽度。

## 2.3. 存储器映射

此 32 位 RISC 处理器采用同一套总线来读取指令和加载/存储数据。指令代码和数据都位于相同的存储器地址空间，但在不同的地址范围。程序存储器，数据存储器，寄存器和 I/O 端口都在同一个线性的 4 GB 的地址空间之内。这是 32 位 RISC 的最大地址范围，因为它的地址总线宽度是 32 位。此外，为了降低不同客户在相同应用时的软件复杂度，存储映射是按 32 位 RISC 处理器提供的规则预先定义的。在存储器映射表中，一部分地址空间由 32 位 RISC 的系统外设所占用，且不可更改。此外，其余部分地址空间可由芯片供应商定义使用。

TX32M2300 系列器件的存储器映射表显示了 TX32M2300 系列器件的存储器映射，包括代码、SRAM、外设和其他预先定义的区域。简化了每个外设的地址译码。



图 2-2 TX32M2300 系列存储器映射表

### 2.3.1. 位带操作

为了减少“读-改-写”操作的次数，32 位 RISC 处理器提供了一个可以执行单原子比特操作的位带功能。存储器映射包含了两个支持位带操作的区域。其中一个是 SRAM 区的最低 1MB 范围，第二个是片内外设区的最低 1MB 范围。这两个区域中的地址除了普通应用外，还有自己的“位带别名区”。位带别名区把每个比特扩展成一个 32 位的字。当用户访问位带

别名区时，就可以达到访问原始比特的目的。

下面的公式表明了位带别名区中的每个字如何对应位带区的相应比特或目标比特。

$$\text{bit\_word\_addr} = \text{bit\_band\_base} + (\text{byte\_offset} \times 32) + (\text{bit\_number} \times 4) \quad (\text{式 3- 1})$$

其中：

- `bit_word_addr` 指的是位带区目标比特对应在位带别名区的地址；
- `bit_band_base` 指的是位带别名区的起始地址；
- `byte_offset` 指的是位带区目标比特所在的字节的字节地址偏移量；
- `bit_number` 指的是目标比特在对应字节中的位置(0-7)。

例如，要想访问 0x2000 0200 地址的第 7 位，可访问的位带别名区地址是：

$$\text{bit\_word\_addr} = 0x2200\ 0000 + (0x200 * 32) + (7 * 4) = 0x2200\ 401C \quad (\text{式 3- 2})$$

如果对 0x2200 401C 进行写操作，那么 0x2000 0200 的第 7 位将会相应变化；如果对 0x2200 401C 进行读操作，那么视 0x2000 0200 的第 7 位状态而返回 0x01 或 0x00。

### 2.3.2. 片上 SRAM 存储器

TX32M2300 系列内置最大可到 6K 字节的静态 SRAM。它可以以字节(8 位)、半字(16 位)或字(32 位)进行访问。SRAM 起始地址为 0x2000 0000。数据总线上最大可到 6K 字节的 SRAM。可以被 CPU 或者 DMA 用最快的系统时钟且不插入任何等待进行访问。DMA 支持访问外设有 timer5、ADC、CRC、SPI0/1、UART0/1、EFLASH。

### 2.3.3. 片上 FLASH 存储器概述

闪存存储器有两个不同存储区域：

- 主闪存存储块，它包括应用程序和用户数据区（若需要时）
- 信息块，其包含两个部分：
  - 选项字节(Option bytes) — 内含硬件及存储保护用户配置选项。
  - 系统存储器(System memory) — 其包含 Boot loader 代码。参见内置闪存存储器章节。

闪存接口基于 AHB 协议执行指令和数据存取。其预取缓冲的功能可加速 CPU 执行代码的速度。

### 2.3.4. 引导配置

芯片复位后，通过客户自己在主闪存存储块的配置，可选择启动模式 pin 脚为 PC6 还是 PC0，默认工作是上拉还是下拉。在启动延迟之后，CPU 从地址 0x0000 0000 获取堆栈顶的地址，并从启动存储器的 0x0000 0004 指示的地址开始执行代码。

内嵌的自举程序存放在系统存储器，由厂家在生产时写入。该程序可以通过 UART0 对闪存进行重新编程。

## 2.4. MCLR 功能

默认状态下 TX32M2300 系列支持 MCLR 复位功能的。MCLR 指在某个特定 IO 引脚上输入一个持续 1.7ms 以上的低电平导致系统复位，如同重新上电复位一样。当用户通过 eflash 中用户自定义 bit 来禁止使能 MCLR 功能后。PE2 会变成普通 IO 功能。详细情况请参考闪存存储器中关于用户自定义区域的描述。

## 3. 嵌入式闪存

### 3.1. 闪存主要特性

- 32K 字节闪存存储器
- 存储器结构：
  - 主闪存空间：32K 字节
  - 副闪存空间（系统存储器）：2K 字节
- 带预取缓冲器的读接口
- 闪存编程和擦除操作
- 访问和写保护
- 低功耗模式

### 3.2. 闪存功能描述

#### 3.2.1. 闪存结构

闪存空间由 32 位宽的存储单元组成，既可以存代码又可以存数据。主闪存块按 32 页（每页 1K 字节）分块，以页为单位设置写保护（参见存储保护相关内容）。

| 模块      | 名称            | 地址                        | 大小(字节) |
|---------|---------------|---------------------------|--------|
| 主闪存空间   | 页 0           | 0x0000_0000 - 0x0000_03FF | 1K     |
|         | 页 1           | 0x0000_0400 - 0x0000_07FF | 1K     |
|         | 页 2           | 0x0000_0800 - 0x0000_0BFF | 1K     |
|         | 页 3           | 0x0000_0C00 - 0x0000_0FFF | 1K     |
|         | ...           | ...                       | 1K     |
|         | 页 30          | 0x0000_7800 - 0x0000_7BFF | 1K     |
|         | 页 31          | 0x0000_7C00 - 0x0000_7FFF | 1K     |
|         |               |                           |        |
| 副闪存空间   | 扇区 0          | 0x1FF0_0000 - 0x1FF0_01FF | 512    |
|         | 扇区 1          | 0x1FF0_0200 - 0x1FF0_03FF | 512    |
|         | 扇区 2          | 0x1FF0_0400 - 0x1FF0_057F | 384    |
|         | 用户参数区         | 0x1FF0_0580 - 0x1FF0_06BF | 64     |
|         | 用户配置区         | 0x1FF0_05C0 - 0x1FF0_05FF | 64     |
|         | 芯片信息区         | 0x1FF0_0600 - 0x1FF0_064F | 80     |
|         | EOTP 芯片区域     | 0x1FF0_0650 - 0x1FF0_068F | 64     |
|         | EOTP 用户区域     | 0x1FF0_0690 - 0x1FF0_06EF | 96     |
| 闪存寄存器接口 | CTRLR0        | 0x4000_3000 - 0x4000_3003 | 4      |
|         | KST           | 0x4000_3004 - 0x4000_3007 | 4      |
|         | DONE          | 0x4000_3008 - 0x4000_300B | 4      |
|         | PROG_ADDR     | 0x4000_3010 - 0x4000_3013 | 4      |
|         | PROG_DATA     | 0x4000_3018 - 0x4000_301B | 4      |
|         | ERASE_CTRL    | 0x4000_3020 - 0x4000_3023 | 4      |
|         | TIME_REG0     | 0x4000_3030 - 0x4000_3033 | 4      |
|         | TIME_REG1     | 0x4000_3034 - 0x4000_3037 | 4      |
|         | NVR_PASSWORD  | 0x4000_3050 - 0x4000_3053 | 4      |
|         | MAIN_PASSWORD | 0x4000_3054 - 0x4000_3057 | 4      |
|         | CRC_ADDR      | 0x4000_3058 - 0x4000_305B | 4      |
|         | CRC_LEN       | 0x4000_305C - 0x4000_305F | 4      |
|         | CRC_OUT       | 0x4000_3060 - 0x4000_3063 | 4      |

### 3.2.2. 闪存读保护

读操作在整个产品工作电压范围内都可以完成，用于存放指令或者数据，Flash运行在36MHz的工作频率上，若工作频率提升到36MHz以上，需要让Flash的读时序执行分频。

芯片带有cache缓冲区和预取缓冲区，提升Flash的访问效率。

若用户配置区打开保护的配置后，当SWD等Debug接口连接上时，会自动对Flash执行保护机制。

读操作有下列2个寄存器完成：

- ①配置寄存器 (CTRLR0)
- ②时序0寄存器 (TIME\_REG0)

### 3.2.3. 闪存烧写和擦除操作

烧写和擦除操作在整个产品工作电压范围内都可以完成。

烧写和擦除操作有下列 6 个寄存器完成，先根据烧写的时钟配置好烧写时序 (TIME\_REG1)，再配置烧写密码，配置好编程地址，最后配置好编程数据，即可开始执行烧写，然后等烧写结束。

只要 CPU 不去访问 Flash 空间，或者访问 Flash 时已经 cache 命中，进行中的 Flash 写操作不会妨碍 CPU 的运行。也就是说，在对 Flash 进行写/擦除操作的同时，任何对 Flash 的访问都会令总线停顿，直到写/擦除操作完成后才会继续执行，这意味着在写/擦除 Flash 的同时不可以对它取指和访问数据

## 3.3. 寄存器

### 3.3.1. 寄存器基址

| Name   | Base Address | Description |
|--------|--------------|-------------|
| Eflash | 0x40003000   | Eflash 的基地址 |

### 3.3.2. 寄存器列表

| Offset Address | Name                | Description           |
|----------------|---------------------|-----------------------|
| 0x0            | EFLASH_CTRLR0       | 控制寄存器                 |
| 0x4            | EFLASH_KST          | 触发寄存器                 |
| 0x8            | EFLASH_DONE         | 状态寄存器                 |
| 0x10           | EFLASH_PROGADDR     | 编程地址寄存器               |
| 0x18           | EFLASH_PROGDATA     | 编程数据寄存器               |
| 0x20           | EFLASH_ERASECTRL    | 擦除控制寄存器               |
| 0x24           | EFLASH_INTFERASEENA | 中断打断 EFlash 工作状态控制寄存器 |
| 0x30           | EFLASH_TIMEREG0     | 时序 0 配置寄存器            |
| 0x34           | EFLASH_TIMEREG1     | 时序 1 配置寄存器            |
| 0x50           | EFLASH_NVRPASSWORD  | NVR 区域秘钥寄存器           |

|      |                     |              |
|------|---------------------|--------------|
| 0x54 | EFLASH_MAINPASSWORD | Main 区域秘钥寄存器 |
| 0x58 | EFLASH_CRCADDR      | CRC 地址寄存器    |
| 0x5C | EFLASH_CRCLEN       | CRC 长度寄存器    |
| 0x60 | EFLASH_CRCOUT       | CRC 输出寄存器    |

### 3.3.3. 寄存器详细说明

#### 3.3.3.1. EFLASH\_CTRLR0

| Bit(s) | Name                  | Description                                                                                                                               | R/W | Reset |
|--------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:20  | Reserved              |                                                                                                                                           | RO  | 0     |
| 19     | Error Interrupt IE    | <b>异常中断的使能位</b><br>使能该中断后，以下异常都会触发：<br>①非对齐地址编程<br>②编程数据错误<br>③无写权限<br>④擦除失败                                                              | RW  | 0     |
| 18     | Normal Interrupt IE   | <b>正常功能的中断使能位</b><br>使能该中断，以下情况会触发：<br>①编程<br>②擦除<br>③CRC 校验<br>④自动编程                                                                     | RW  | 0     |
| 17     | Reserved              |                                                                                                                                           | RO  | 0     |
| 16     | Program Clock select  | <b>Eflash 烧写时钟源选择，推荐使用 RC 时钟</b><br>0x0: 高速 RC 时钟 2 分频<br>0x1: 晶振，若 RC 不准时才使用                                                             | RW  | 0     |
| 15:12  | Reserved              |                                                                                                                                           | RO  | 0     |
| 11     | LVD Program Disable   | <b>LVD 掉电烧录控制位</b><br>在 LVD 断电时，是否允许打断 eflash program 和 erase，一般在断电时，立刻把重要数据保存在 eflash 上，就打开此功能，用于快速让 eflash 处于空闲状态<br>0x0: 关闭<br>0x1: 打开 | RW  | 0     |
| 10:6   | Reserved              |                                                                                                                                           | RO  | 0     |
| 5      | Block request Mode    | <b>Program/Erase 的请求缓冲模式（测试使用）</b><br>0x0: 关闭<br>0x1: 打开                                                                                  | RW  | 0     |
| 4      | Cache Write Back Mode | <b>Program/Sector Erase 自动回写到 cache（测试使用）</b>                                                                                             | RW  | 1     |

|   |                 |                                        |    |   |
|---|-----------------|----------------------------------------|----|---|
|   |                 | 0x0: 关闭<br>0x1: 打开                     |    |   |
| 3 | Reserved        |                                        | RO | 1 |
| 2 | Prefetch Enable | <b>预取使能位</b><br>0x0: 关闭<br>0x1: 打开     | RW | 0 |
| 1 | Reserved        |                                        | RO | 0 |
| 0 | Cache Enable    | <b>Cache 使能位</b><br>0x0: 关闭<br>0x1: 打开 | RW | 0 |

### 3.3.3.2. EFLASH\_KST

| Bit(s) | Name                        | Description                                                       | R/W | Reset |
|--------|-----------------------------|-------------------------------------------------------------------|-----|-------|
| 31     | EFLASH Error Clear Enable   | <b>异常标志清除使能位</b><br>注意：需要与 BIT[15]同时配置才有效<br>0x0: 关闭<br>0x1: 打开   | WO  | 0     |
| 30     | EFLASH Pending Clear Enable | <b>完成状态标志清除使能位</b><br>注意：需要与 BIT[14]同时配置才有效<br>0x0: 关闭<br>0x1: 打开 | WO  | 0     |
| 29:27  | Reserved                    |                                                                   | RO  | 0     |
| 26     | CRC Kick Enable             | <b>CRC 触发使能位</b><br>注意：需要与 BIT[10]同时配置才有效<br>0x0: 关闭<br>0x1: 打开   | WO  | 0     |
| 25     | Auto Program EFLASH Enable  | <b>自动编程使能位</b><br>注意：需要与 BIT[9]同时配置才有效<br>0x0: 关闭<br>0x1: 打开      | WO  | 0     |
| 24     | Auto Program RAM Enable     | <b>SRAM 自动编程使能位</b><br>注意：需要与 BIT[8]同时配置才有效<br>0x0: 关闭<br>0x1: 打开 | WO  | 0     |
| 23:21  | Reserved                    |                                                                   | RO  | 0     |
| 20     | Cache Clear Kick Enable     | <b>Cache 清除使能位</b><br>注意：需要与 BIT[4]同时配置才有效<br>0x0: 关闭<br>0x1: 打开  | WO  | 0     |
| 19:11  | Reserved                    |                                                                   | RO  | 0     |
| 15     | EFLASH Error Clear          | <b>异常标志清除位</b><br>注意：需要与 BIT[31]同时配置才有效<br>写 1 清除                 | WO  | 0     |
| 14     | EFLASH Pending Clear        | <b>完成状态标志清除位</b>                                                  | WO  | 0     |

|       |                                |                                                                  |    |   |
|-------|--------------------------------|------------------------------------------------------------------|----|---|
|       |                                | 注意：需要与 BIT[14]同时配置才有效<br>写1清除                                    |    |   |
| 13:11 | Reserved                       |                                                                  | RO | 0 |
| 10    | CRC Kick Start                 | <b>CRC 触发位</b><br>注意：需要与 BIT[26]同时配置才有效<br>0x0：关闭<br>0x1：打开      | WO | 0 |
| 9     | Auto Program EFLASH Kick start | <b>自动编程触发位</b><br>注意：需要与 BIT[25]同时配置才有效<br>0x0：关闭<br>0x1：打开      | WO | 0 |
| 8     | Auto Program RAM Kick start    | <b>SRAM 自动编程触发位</b><br>注意：需要与 BIT[24]同时配置才有效<br>0x0：关闭<br>0x1：打开 | WO | 0 |
| 7:5   | Reserved                       |                                                                  | RO | 0 |
| 4     | Cache Clear Kick Start         | <b>Cache 清除位</b><br>注意：需要与 BIT[20]同时配置才有效<br>0x0：关闭<br>0x1：打开    | WO | 0 |
| 3:0   | Reserved                       |                                                                  | RO | 0 |

### 3.3.3.3. EFLASH\_DONE

| Bit(s) | Name                   | Description                                                              | R/W | Reset |
|--------|------------------------|--------------------------------------------------------------------------|-----|-------|
| 31     | EFLASH Error           | <b>Error 状态标志位</b><br>0x0：正常<br>0x1：异常                                   | RO  | 0     |
| 30:20  | Reserved               |                                                                          | RO  | 0     |
| 19     | Chip Erase Error       | <b>全片擦除异常状态</b><br>0x0：工作正常<br>0x1：擦除异常，error 有效                         | RO  | 0     |
| 18     | Write permission Error | <b>编程权限异常状态</b><br>0x0：工作正常<br>0x1：无编程权限，error 有效                        | RO  | 0     |
| 17     | Program Address Error  | <b>编程地址异常状态</b><br>0x0：工作正常<br>0x1：非对齐地址，error 有效                        | RO  | 0     |
| 16     | Program Data Error     | <b>编程数据异常状态</b><br>已经编程的数据是否和软件配置的数据一致<br>0x0：工作正常<br>0x1：数据不一致，error 有效 | RO  | 0     |
| 15     | EFLASH Busy            | Eflash 工作状态标志                                                            | RO  | 0     |

|       |                          |                                                   |    |   |
|-------|--------------------------|---------------------------------------------------|----|---|
|       |                          | 0x0: 空闲状态<br>0x1: 进行中                             |    |   |
| 14:11 | Reserved                 |                                                   | RO | 0 |
| 10    | CRC Done                 | <b>CRC 完成标志</b><br>0: 进行中<br>1: 空闲状态              | RO | 1 |
| 9     | Auto Program EFLASH Done | <b>自动编程 eflash 完成标志</b><br>0x0: 空闲<br>0x1: 结束     | RO | 0 |
| 8     | Auto Program RAM Done    | <b>自动编程 RAM 完成标志</b><br>0x0: 空闲<br>0x1: 结束        | RO | 0 |
| 7     | Reserved                 |                                                   | RO | 0 |
| 6     | Program Done             | <b>Program 结束标志</b><br>0x0: 进行中<br>0x1: 空闲状态      | RO | 1 |
| 5     | Reserved                 |                                                   | RO | 0 |
| 4     | Cache Clear Done         | <b>Cache 初始化标志</b><br>0x0: 进行中<br>0x1: 空闲状态       | RO | 1 |
| 3:2   | Reserved                 |                                                   | RO | 0 |
| 1     | Chip Erase Done          | <b>Main 区域全擦除标志</b><br>0x0: 正在运行<br>0x1: 空闲状态     | RO | 1 |
| 0     | Sector Erase Done        | <b>扇区(512 byte)擦除标志</b><br>0x1: 正在运行<br>0x0: 空闲状态 | RO | 1 |

### 3.3.3.4. EFLASH\_PROGADDR

| Bit(s) | Name               | Description                                                                                                                                                          | R/W | Reset |
|--------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:30  | Program Byte       | <b>编程的位宽设置</b><br>eflash 通过功能区的 DATA RAM 设置, 分为 code 区域和 RAM 区域, 其中 RAM 区域可以执行 1/2/4 byte 的编程, 而 code 区域只能执行 4 byte 的编程<br>0x0: 1 byte<br>0x1: 2 byte<br>0x2: 4 byte | RW  | -     |
| 29     | Program NVR Select | <b>编程的地址是否 NVR 区域</b><br>0x0: MAIN 区域<br>0x1: NVR 区域                                                                                                                 | RW  | -     |
| 28:0   | Program Address    | <b>eflash 编程的地址</b><br>在自动编程模式下, 作为目的地址:<br>在自动编程 RAM 模式下, 此地址作为 RAM 地址;                                                                                             | RW  | -     |

|  |  |                                                                                                                                                                                                                            |  |  |
|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|  |  | <p>在自动编程 EFLASH 模式下, 此地址作为 EFLASH 地址。</p> <p>在 code 区域里编程:</p> <p>仅支持 4 byte 编程</p> <p>在 DATARAM 区域里编程:</p> <p>编程地址为 half word 对齐, 支持 1/2 byte 编程</p> <p>编程地址为 word 对齐, 支持 1/2/4 byte 编程</p> <p>编程地址为奇数, 仅支持 1 byte 编程</p> |  |  |
|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|

### 3.3.3.5. EFLASH\_PROGDATA

| Bit(s) | Name         | Description               | R/W | Reset |
|--------|--------------|---------------------------|-----|-------|
| 31:0   | Program Data | eflash 编程的数据, 需要配置好地址才可进行 | RW  | 0     |

### 3.3.3.6. EFLASH\_ERASECTRL

| Bit(s) | Name                    | Description                                 | R/W | Reset |
|--------|-------------------------|---------------------------------------------|-----|-------|
| 31     | Chip Erase Kick Start   | Chip 全擦除的触发<br>写“1”触发, 需要先配置密码              | RO  | 0     |
| 30     | Sector Erase Kick Start | Sector 擦除的触发<br>写“1”触发, 需要先配置密码             | RO  | 0     |
| 29     | NVR Sector Enable       | NVR 的 sector 使能位<br>0: MAIN 区域<br>1: NVR 区域 | RW  | 0     |
| 28:7   | Reserved                |                                             | RO  | 0     |
| 6:0    | Erase Sector Address    | 擦除的 sector 选择, 范围 0-127                     | RW  | 0     |

### 3.3.3.7. EFLASH\_TIMEREG0

| Bit(s) | Name     | Description                                                         | R/W | Reset |
|--------|----------|---------------------------------------------------------------------|-----|-------|
| 31:20  | Reserved |                                                                     | RO  | 0     |
| 19:16  | PGH      | WEB low to PROG2 high hold min time is 15ns                         | RW  | 1     |
| 15:12  | ADS      | BYTE/Address/data setup min time is 15ns                            | RW  | 1     |
| 11:8   | ADH      | BYTE/Address/data hold min time is 15ns                             | RW  | 1     |
| 7:4    | RW       | Latency to next operation after PROG/ERASE<br>low min time is 100ns | RW  | 8     |
| 3:0    | RC       | Read Cycle Min Time is 25/30ns                                      | RW  | 0     |

### 3.3.3.8. EFLASH\_TIME\_REG1

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|--------|------|-------------|-----|-------|

|       |          |                         |    |      |
|-------|----------|-------------------------|----|------|
| 31:20 | Reserved |                         | RO | 0    |
| 18:8  | 1ms unit | 1ms 的时间配置值, 以 1us 为单位   | RW | 1000 |
| 7:0   | 1us unit | 1us 的时间配置值, 系统默认是 26MHz | RW | 26   |

### 3.3.3.9. EFLASH\_NVR\_PASSWORD

| Bit(s) | Name         | Description                              | R/W | Reset |
|--------|--------------|------------------------------------------|-----|-------|
| 31:10  | NVR password | 密码为 0x20150931, 只有打开密码后, 才能对 NVR 进行擦除和编程 | RW  | 0     |

### 3.3.3.10. EFLASH\_MAIN\_PASSWORD

| Bit(s) | Name          | Description                               | R/W | Reset |
|--------|---------------|-------------------------------------------|-----|-------|
| 31:10  | Main password | 密码为 0x20170230, 只有打开密码后, 才能对 Main 进行擦除和编程 | RW  | 0     |

### 3.3.3.11. EFLASH\_CRC\_ADDR

| Bit(s) | Name        | Description                                                                                | R/W | Reset |
|--------|-------------|--------------------------------------------------------------------------------------------|-----|-------|
| 31:30  | Reserved    |                                                                                            | RO  | 0     |
| 29     | NVR Select  | 地址是否 NVR 区域<br>0x0: MAIN 区域<br>0x1: NVR 区域                                                 | RW  | 0     |
| 28:2   | DMA Address | CRC DMA 的开始地址, 作为源地址<br>在自动编程 RAM 模式下, 此地址作为 EFLASH 地址;<br>在自动编程 EFLASH 模式下, 此地址作为 RAM 地址。 | RW  | 0     |
| 1:0    | Reserved    | 保留, 低 2 位地址固定为 0, word 对齐                                                                  | RO  | 0     |

### 3.3.3.12. EFLASH\_CRC\_LEN

| Bit(s) | Name       | Description               | R/W | Reset |
|--------|------------|---------------------------|-----|-------|
| 31:2   | DMA length | CRC DMA 的长度               | RW  | 0     |
| 1:0    | Reserved   | 保留, 低 2 位地址固定为 0, word 对齐 | RO  | 0     |

### 3.3.3.13. EFLASH\_CRC\_OUT

| Bit(s) | Name       | Description                            | R/W | Reset |
|--------|------------|----------------------------------------|-----|-------|
| 31:00  | CRC Result | CRC 结果输出<br>多项式 CRC-32 如下, 出来的结果取反就是官方 | RO  | 0     |

|  |  |                                                                                             |  |  |
|--|--|---------------------------------------------------------------------------------------------|--|--|
|  |  | 的结果，写入 EFLASH 的 CRC 需要官方的值取反表示！！！<br>x32+x26+x23+x22+x16+x12+x11+x10+x8+x7+x5<br>+x4+x2+x+1 |  |  |
|--|--|---------------------------------------------------------------------------------------------|--|--|

## 4. 中断和事件

### 4.1. 嵌套向量中断控制器

基本功能：

- 中断都可屏蔽（除了 NMI）
- 16 个可编程的优先等级（使用了 4 位中断优先级）
- 低延迟的异常和中断处理
- 电源管理控制
- 系统控制寄存器的实现

嵌套向量中断控制器（NVIC）和处理器核的接口紧密相连，可以实现低延迟的中断处理和高效地处理晚到的中断。

嵌套向量中断控制器管理着包括核异常等中断。关于更多的异常和 NVIC 编程的说明请参考 CPU 技术参考手册。

### 4.2. 系统嘀嗒（SysTick）校准值寄存器

本芯片不支持使用外部时钟计时 1ms。

### 4.3. 中断功能描述

处理器和嵌套式矢量型中断控制器(NVIC)在处理(Handler)模式下对所有异常进行优先级区分以及处理。当异常发生时，系统自动将当前处理器工作状态压栈，在执行完中断服务子程序 (ISR) 后自动将其出栈。

取向量是和当前工作态压栈并行进行的，从而提高了中断入口效率。处理器支持咬尾中断，可实现背靠背中断，大大削减了反复切换工作态所带来的开销。NVIC 异常类型列出了所有的异常类型。

表 4-1 CPU 中的 NVIC 异常类型

| 异常类型         | 向量号  | 优先级 | 向量地址                  | 描述                |
|--------------|------|-----|-----------------------|-------------------|
| -            | 0    | -   | 0x00000000            | 保留                |
| 复位           | 1    | -3  | 0x00000004            | 复位                |
| NMI          | 2    | -2  | 0x00000008            | 不可屏蔽中断            |
| HardFault    | 3    | -1  | 0x0000000C            | 各种硬件级别故障          |
| MemManage    | 4    | 可设置 | 0x00000010            | 存储器管理             |
| BusFault     | 5    | 可设置 | 0x00000014            | 预取指故障，存储器访问故障     |
| UsageFault   | 6    | 可设置 | 0x00000018            | 未定义的指令或者非法状态      |
| -            | 7-10 | -   | 0x0000001C-0x0000002B | 保留                |
| SVcall       | 11   | 可设置 | 0x0000002C            | 通过 SWI 指令实现系统服务调用 |
| DebugMonitor | 12   | 可设置 | 0x00000030            | 调试监控器             |
| -            | 13   | -   | 0x00000034            | 保留                |
| PendSV       | 14   | 可设置 | 0x00000038            | 可挂起的系统服务请求        |
| Systick      | 15   | 可设置 | 0x0000003C            | 系统节拍定时器           |

SysTick 校准值设为 0x1196E，SysTick 时钟频率配置为 HCLK，此时若 HCLK 时钟被配置为 72MHz，则 SysTick 中断会 1ms 响应一次。

表 4-2 中断向量表

| 中断序号  | 向量号 | 外设中断描述          | 向量地址        |
|-------|-----|-----------------|-------------|
| IRQ0  | 16  | lvd_int         | 0x0000_0040 |
| IRQ1  | 17  | uart0_int       | 0x0000_0044 |
| IRQ2  | 18  | uart1_int       | 0x0000_0048 |
| IRQ3  | 19  | spi0_int        | 0x0000_004C |
| IRQ4  | 20  | spil_int        | 0x0000_0050 |
| IRQ5  | 21  | gpioa_int       | 0x0000_0054 |
| IRQ6  | 22  | gpiob_int       | 0x0000_0058 |
| IRQ7  | 23  | gpioe_int       | 0x0000_005C |
| IRQ8  | 24  | wkpnd_int       | 0x0000_0060 |
| IRQ9  | 25  | timer0_int      | 0x0000_0064 |
| IRQ10 | 26  | timer1_int      | 0x0000_0068 |
| IRQ11 | 27  | timer2_int      | 0x0000_006C |
| IRQ12 | 28  | timer3_int      | 0x0000_0070 |
| IRQ13 | 29  | timer4_int      | 0x0000_0074 |
| IRQ14 | 30  | timer5_int      | 0x0000_0078 |
| IRQ15 | 31  | epwm_tzint      | 0x0000_007C |
| IRQ16 | 32  | epwm_etint      | 0x0000_0080 |
| IRQ17 | 33  | adkey_interrupt | 0x0000_0084 |

|       |    |               |             |
|-------|----|---------------|-------------|
| IRQ18 | 34 | div_ovf_int   | 0x0000_0088 |
| IRQ19 | 35 | crc_dma_int   | 0x0000_008C |
| IRQ20 | 36 | comp_int      | 0x0000_0090 |
| IRQ21 | 37 | wdt_interrupt | 0x0000_0094 |
| IRQ22 | 38 | eflash_int    | 0x0000_0098 |
| IRQ23 | 39 | adkey_int1    | 0x0000_009C |
| IRQ24 | 40 | -             | 0x0000_00A0 |
| IRQ25 | 41 | -             | 0x0000_00A4 |
| IRQ26 | 42 | -             | 0x0000_00A8 |
| IRQ27 | 43 | -             | 0x0000_00AC |
| IRQ28 | 44 | -             | 0x0000_00B0 |
| IRQ29 | 45 | -             | 0x0000_00B4 |
| IRQ30 | 46 | -             | 0x0000_00B8 |
| IRQ31 | 47 | -             | 0x0000_00BC |

## 4.4. 外部中断/事件控制器（EXTI）

外部中断和时间控制器（EXTI）管理外部和内部异步事件/中断，并生成相应的事件请求到 CPU/中断控制器和到电源管理的唤醒请求。每个输入线可以独立地配置输入类型（脉冲或挂起）和对应的触发事件（上升沿或下降沿或者双边沿都触发）。每个输入线都可以独立地被屏蔽。挂起寄存器保持着状态线的中断请求。

### 4.4.1. 主要特征

EXTI 控制器的主要特性如下：

- 每个中断/事件都有独立的触发和屏蔽
- 每个中断线都有专用的状态位
- 支持多达 20 个软件的中断/事件请求
- 检测脉冲宽度低于 APB0 时钟宽度的外部信号

参见数据手册中电气特性部分的相关参数

#### 4.4.2. 唤醒事件管理

TX32M2300 系列可以处理外部或内部事件来唤醒内核（WFE）。唤醒事件可以通过下述配置产生：

- 外设的控制寄存器使能一个中断，但不在 NVIC 中使能，同时在 CPU 的系统控制寄存器中使能 SEVONPEND 位。当 CPU 从 WFE 恢复后，需要清除相应外设的中断挂起位和外设 NVIC 中断通道挂起位（在 NVIC 中断清除挂起寄存器中）。
- 配置一个外部或内部 EXTI 线为事件模式，当 CPU 从 WFE 恢复后，因为对应事件线的挂起位没有被置位，不必清除相应外设的中断挂起位或 NVIC 中断通道挂起位。

### 5. 电源控制

#### 5.1. 电源

芯片的工作电压（VCC）为 2.0V ~ 5.5V。本芯片采用 CAPLESS 设计，无需在内置 LDO 输出上外挂电容。

##### 5.1.1. 电压调节器

复位后调节器总是使能的。在需要低功耗的场合，可以使能低功耗工作模式，PMUCON0.ipen 做为功耗模式切换控制位。

## 5.2. 电源管理器

### 5.2.1. 上电复位 (POR) 和掉电复位 (PDR)

TX32M2300 系列内部有一个完整的上电复位 (POR) 和掉电复位 (PDR) 电路，当供电电压达到 2.7V

时系统既能正常工作。当 VDD 低于指定的限位电压 VPOR/VPDR 时，系统保持为复位状态，而无需外部复位电路。



图 6-1 上电复位和掉电复位

### 5.2.2. 可编程电压监测器 (PWD)

TX32M2300 系列内部集成两个电压检测器，一个检测外部供电 VCC, 一个检测内部 LDO 输出 VDD，LDO 采样 capless 结构，封装上 VDD 不可见。两种检测电压均阈值可选。当系统监测到 VCC 或 VDD 电压低于配置电压值时，可以选择触发系统复位或通过使能 PVD 中断进入中断子函数。这一特性可用于用于执行紧急关闭任务。检测信号可以选择经过毛刺滤波电路或直接检测，由 LVD\_CON.lvdvcc\_bps\_en 和 LVD\_CON.lvdvdd\_bps\_en 来控制。



图 6-2 PVD 示意图

### 5.3. 低功耗模式

在系统或电源复位以后，微控制器处于运行状态，系统所用时钟为 256Khz 内部 RC。当 CPU 不需继续运行时，可以利用多种低功耗模式来节省功耗，例如等待某个外部事件时。用户需要根据最低电源消耗、最快速启动时间和可用的唤醒源等条件，选定一个最佳的低功耗模式。

TX32M2300 系列有三种低功耗模式：

- IDLE 模式（CPU 停止，所有外设包括 CPU 的外设，如 NVIC、系统时钟（SysTick）等仍在运行）
- STOP 模式（CPU，大部分外设停止，可依赖其他时间唤醒此模式后芯片继续运行）
- SLEEP 模式（所有时钟源都停止，依赖外部 IO 唤醒，可以选择复位芯片或继续运行）

此外，在运行模式下，可以通过以下方式中的一种降低功耗：

- 降低系统时钟
- 关闭 APB 和 AHB 总线上未被使用的外设时钟
- 合理配置 APB 与 AHB 的频率关系

## 5.4. 寄存器

### 5.4.1. 寄存器地址

| Name | Base Address | Description |
|------|--------------|-------------|
| LVD  | 0x40000100   | LVD 的基址     |

### 5.4.2. 寄存器列表

| Offset Address | Name    | Description |
|----------------|---------|-------------|
| 0x00           | LVD_CON | 配置寄存器       |

### 5.4.3. 寄存器详细说明

#### 5.4.3.1. LVD\_CON

| Bit(s) | Name            | Description                                                | R/W | Reset |
|--------|-----------------|------------------------------------------------------------|-----|-------|
| 31     | lvdvdd_pending  | VDD 电压低于设定阈值触发 pending<br>write 0 clean this bit           | R   | 0     |
| 30     | lvdvcc_pending  | VCC 电压低于设定阈值触发 pending<br>write 0 clean this bit           | R   | 0     |
| 29     | Reserved        |                                                            | -   | -     |
| 28:22  | dbs_lo_limit    | 滤波检测电压信号低毛刺宽度<br>单位为 LVDBS_CLK                             | RW  | 0     |
| 21:15  | dbs_hi_limit    | 滤波检测电压信号高毛刺宽度<br>单位为 LVDBS_CLK                             | RW  | 0     |
| 14     | lvdvcc_sync_dis | 检测到VCC 低电压信号触发 LVDVCC 低电唤醒源是否需要同步<br>0x0: 需要同步<br>0x1: 不同步 | RW  | 0     |
| 13     | lvdvdd_bps_en   | 使能采样 debounce 后的 VDD 电压状态信号<br>0x0: 关闭<br>0x1: 打开          | RW  | 0     |
| 12     | lvdvcc_bps_en   | 使能采样 debounce 后的 VCC 电压状态信号<br>0x0: 关闭<br>0x1: 打开          | RW  | 0     |
| 11     | lvd_oe          | 使能阈值判断触发条件后中断, 以及复位功能<br>0x0: 关闭                           | RW  | 1     |

|     |               |                                                                                                                                                                                                                                                                                                                                                                               |    |     |
|-----|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |               | 0x1: 打开                                                                                                                                                                                                                                                                                                                                                                       |    |     |
| 10  | lvdvdd_RST_en | <b>VDD 阈值判断触发后复位系统使能</b><br>0x0: 中断, 不复位<br>0x1: 复位, 不中断                                                                                                                                                                                                                                                                                                                      | RW | 1   |
| 9   | lvdvcc_RST_en | <b>VCC 阈值判断触发后复位系统使能</b><br>0x0: 中断, 不复位<br>0x1: 复位, 不中断                                                                                                                                                                                                                                                                                                                      | RW | 1   |
| 8:4 | hlvd_s        | <b>VCC LVD 档位设置</b><br>0x00: 1. 7<br>0x01: 1. 8<br>0x02: 1. 9<br>0x03: 2<br>0x04: 2. 1<br>0x05: 2. 2<br>0x06: 2. 3<br>0x07: 2. 4<br>0x08: 2. 55<br>0x09: 2. 65<br>0x0A: 2. 8<br>0x0B: 2. 95<br>0x0C: 3. 1<br>0x0D: 3. 25<br>0x0E: 3. 4<br>0x0F: 3. 55<br>0x10: 3. 35<br>0x11: 3. 55<br>0x12: 3. 75<br>0x13: 3. 95<br>0x14: 4. 15<br>0x15: 4. 35<br>0x16: 4. 55<br>0x17: 4. 75 | RW | 0x9 |
| 3:2 | llvd_s        | <b>VDD LVD 档位设置</b><br>0x0: 0. 99<br>0x1: 1. 09<br>0x2: 1. 19<br>0x3: 1. 29                                                                                                                                                                                                                                                                                                   | RW | 0x2 |
| 1   | llvd_en       | <b>VDD LVD 使能位</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                                                                                                                                      | RW | 1   |
| 0   | hlvd_en       | <b>VCC LVD 使能位</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                                                                                                                                      | RW | 1   |

## 6. 复位和时钟控制

### 6.1. 复位

TX32M2300 系列支持电源复位和系统复位和主复位。

#### 6.1.1. 系统复位

系统复位将复位除某些复位状态寄存器和特殊功能寄存器之外的所有寄存器。

当以下事件中的一件发生时，产生一个系统复位：

SLEEP 模式下外部 IO 口/LVDVCC 低电/COMPO 唤醒；

WDT 计数溢出复位

系统复位请求复位

UART0 升级程序复位

系统锁定复位

### 6.2. 主复位

主复位能将部分系统复位无法复位的寄存器复位。

以下事件可以触发一个主复位：

软件复位

PVD 检测到电压低事件，且控制器处于复位功能模式

当芯片支持 MCLR 复位时，MCLR 脚上一个持续 1ms 以上的低电平，触发复位

#### 6.2.1. 电源复位

上电/掉电复位（POR/PDR 复位）都属于电源复位。电源复位将复位所有的逻辑和模拟模块。

复位入口矢量被固定在地址 0x0000\_0004。

## 6.3. 时钟

### 6.3.1. XOSC 时钟

高速外部时钟信号（XOSC）由以下两种时钟源产生：

- 外部晶体/陶瓷谐振器
- 用户外部时钟

### 6.3.2. HIRC 时钟

HIRC 时钟信号由内部 26MHz 的振荡器产生，可直接作为系统时钟或作为 PLL 输入。

HIRC 振荡器能够在不需要任何外部器件的条件下提供系统时钟。它的启动时间比 XOSC 晶体振荡器短。然而，即使在校准之后它的时钟频率精度仍较差。需要出厂时校准，校准值写在 flash 系统存储区域。可以程序在使用这个时钟前，可以读取并配置出高精度的 HIRC 时钟。经过出厂效验后，常温状态下 HIRC 精度为 26MHz(+/- 1.5%)。精确的频率在 0x1FF0\_0600 – 0x1FF0\_06FF 闪存区域有描述，用户可通过读取得到 HIRC 的精确频率。

如果 XOSC 晶体振荡器失效， HIRC 时钟会被作为备用时钟源。参考时钟安全系统（CSS）。

### 6.3.3. PLL

内部 PLL 可以用内部时钟源如 XOSC, HIRC 等做为参考，系统配置小数分频比得到想要的任意时钟频率，经过分频电路后可以作为系统时钟。

### 6.3.4. LIRC 时钟

LIRC 振荡器担当一个低功耗时钟源的角色，它作为系统启动时钟为看门狗和其他单元提供时钟。 LIRC 时钟频率大约 128KHz（在 90KHz 和 166KHz 之间）。进一步信息请参考数

据手册中有关电气特性部分。

### 6.3.5. 系统时钟 (SYSCLK) 选择

四种不同的时钟源可被用来驱动系统时钟 (SYSCLK) :

- 内部低速 128Khz LIRC
- 内部高速 26Mhz HIRC
- 外部高速晶振 XOSC
- 片内高速 PLL 时钟

### 6.3.6. DBSCLK 选择

四种不同的时钟源可被用来驱动 GPIO 的 glitch debounce clock (DBSCLK) :

- 外部高速晶振 XOSC
- 内部高速 26Mhz HIRC 的分频时钟
- SYSCLK
- 内部低速 128Khz LIRC

### 6.3.7. LVDDBS\_CLK 时钟选择

四种不同的时钟源可被用来驱动 LVD VCC/VDD 的 debounce clock (LVDDBS\_CLK) , 独立于系统时钟而工作 :

- APB0CLK
- 内部高速 26Mhz HIRC 的分频时钟
- 内部低速 128Khz LIRC
- 外部高速晶振 XOSC

### 6.3.8. CMPCLK 时钟选择

四种不同的时钟源可被用来驱动 comparor 的 clock (CMPCLK) :

- 内部低速 128Khz LIRC
- 内部高速 26Mhz HIRC 的分频时钟
- 系统时钟
- 外部高速晶振 XOSC

当不被使用时，任一个时钟源都可被独立地启动或关闭，由此优化系统功耗。



图 7-1 时钟结构

### 6.3.9. 时钟安全系统 (CSS)

时钟安全系统可以通过软件被激活。在使用这个功能时,请确保 XOSC 已经被成功使能。如果 XOSC 时钟发生故障,产生时钟安全中断 CSSI,允许软件完成营救操作。此 CSSI 中断连接到 CPU 的 NMI 中断。注:一旦 CSS 被激活,并且 XOSC 时钟出现故障,CSS 中断就产生,并且 NMI 也自动产生。NMI 将被不断执行,直到 CSS 中断挂起位被清除。因此,在 NMI 的处理程序中必须通过设置时钟中断寄存器,(HOSC\_MNT) 里的 hosc\_loss\_pending 位写 1 来清除 CSS 中断。通过寄存器使能,时钟故障将导致内部 XOSC 时钟自动切换到 hirc\_div\_clk。

## 6.4. 寄存器

### 6.4.1. 寄存器基址

| Name   | Base Address | Description |
|--------|--------------|-------------|
| System | 0x40020000   | System 的基地址 |

### 6.4.2. 寄存器列表

表 7-1 寄存器列表

| Offset Address | Name     | Description  |
|----------------|----------|--------------|
| 0x0000         | SYS_KEY  | 系统配置 key 寄存器 |
| 0x0004         | SYS_CON0 | 系统控制寄存器 0    |
| 0x0008         | SYS_CON1 | 系统控制寄存器 1    |
| 0x000c         | SYS_CON2 | 系统控制寄存器 2    |
| 0x0010         | SYS_CON3 | 系统控制寄存器 3    |
| 0x0014         | SYS_CON4 | 系统控制寄存器 4    |
| 0x0018         | SYS_CON5 | 系统控制寄存器 5    |
| 0x001c         | SYS_CON6 | 系统控制寄存器 6    |
| 0x0020         | SYS_CON7 | 系统控制寄存器 7    |
| 0x0024         | CLK_CON0 | 时钟控制寄存器 0    |
| 0x0028         | CLK_CON1 | 时钟控制寄存器 1    |
| 0x002c         | CLK_CON2 | 时钟控制寄存器 2    |

|        |            |                             |
|--------|------------|-----------------------------|
| 0x0030 | CLK_CON3   | 时钟控制寄存器 3                   |
| 0x0034 | CLK_CON4   | 时钟控制寄存器 4                   |
| 0x0038 | CLK_CON5   | 时钟控制寄存器 5                   |
| 0x003c | CLK_CON6   | 时钟控制寄存器 6                   |
| 0x0040 | CLK_CON7   | 时钟控制寄存器 7                   |
| 0x0044 | HOSC_MNT   | XOSC 控制寄存器                  |
| 0x0048 | SYS_ERR    | 系统异常错误寄存器                   |
| 0x004c | WKUP_CON   | Wakeup 寄存器                  |
| 0x0050 | LP_CON     | 低功耗寄存器                      |
| 0x0054 | MBIST_CON  | Memory Bist 寄存器             |
| 0x0058 | MBIST_MISR | Memory Bist Rom result 寄存器  |
| 0x005c | RESERVED   |                             |
| 0x0060 | MODE       | 模式配置寄存器                     |
| 0x0064 | PMU_CON    | PMU 控制器                     |
| 0x0068 | RPCON      | System pending recording    |
| 0x006c | AMP_CON0   | AMP 控制寄存器 0                 |
| 0x0070 | AMP_CON1   | AMP 控制寄存器 1                 |
| 0x0074 | PMUBK      | PMU lower power mode backup |

### 6.4.3. 寄存器定义

#### 6.4.3.1. SYS\_KEY

| Bit(s) | Name    | Description                                                                                                                                  | R/W | Reset |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:0   | sys_key | 系统寄存器配置 key<br>写入 0x3fac87e4 使所有系统寄存器写入使能，<br>Setsys_keyother 值将清除此位 other 值将清除<br>此位。读取返回 sys_key 状态<br>0x0: 锁定所有系统寄存器写入<br>0x1: 解锁所有系统寄存器写 | RW  | 0x1   |

#### 6.4.3.2. SYS\_CON0

| Bit(s) | Name              | Description                                                                                                       | R/W | Reset |
|--------|-------------------|-------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31     | fast_RST_en       | 快速复位使能<br>复位时间会在 1ms ~62us                                                                                        | R/W | 0x0   |
| 30     | sleep_goon_en     | 触发 wakeup 后，是否继续运行<br>0x0: 复位<br>0x1: 继续运行                                                                        | R/W | 0x0   |
| 29:27  | sleep_dly_cnt     | Wakeup 后延迟 goon 运行时间配置<br>0x0: two 128K RC cycles<br>0x1: three 128K RC cycles<br>...<br>0x7: nine 128K RC cycles | R/W | 0x0   |
| 26     | dbs_soft_RST_     | GPIO debounce 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                         | R/W | 0x1   |
| 25     | crc_soft_RST_     | CRC 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                                   | R/W | 0x1   |
| 24:21  | Reserved          |                                                                                                                   | R/W | 0xF   |
| 20     | gpio_soft_RST_    | GPIOA/GPIOB/GPIOE 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                     | R/W | 0x1   |
| 19     | adkey_soft_RST_   | ADCKey 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                                | R/W | 0x1   |
| 18     | uart1_soft_RST_   | UART1 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                                 | R/W | 0x1   |
| 17     | uart0_soft_RST_   | UART0 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                                 | R/W | 0x1   |
| 16     | spil_soft_RST_    | SPI1 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                                  | R/W | 0x1   |
| 15     | spi0_soft_RST_    | SPI0 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                                  | R/W | 0x1   |
| 14     | epwm_soft_RST_    | EPWM 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                                  | R/W | 0x1   |
| 13:9   | Reserved          |                                                                                                                   | R/W | 0x1F  |
| 8      | wdt_soft_RST_     | WDT 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                                   | R/W | 0x1   |
| 7      | wdt_SYS_soft_RST_ | WDT SYS 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                               | R/W | 0x1   |
| 6      | timer_soft_RST_   | TIMER 软件复位<br>先写 0, 后写 1 才能完成复位操作                                                                                 | R/W | 0x1   |
| 5:0    | Reserved          | For future usage                                                                                                  | R/W | 0x3F  |

#### 6.4.3.3. SYS\_CON1

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|       |                   |                                                                                   |     |     |
|-------|-------------------|-----------------------------------------------------------------------------------|-----|-----|
| 31:14 | Reserved          |                                                                                   | -   | -   |
| 13    | uart_update_dis   | <b>串口单 pin 升级</b><br>0x0: 打开<br>0x1: 关闭                                           | R/W | 0x0 |
| 12    | debug_en          | <b>Sleep 模式与 debug 联动配置</b><br>Sleep、stopclk 模式将在调试连接时自动唤醒。<br>0x0: 打开<br>0x1: 关闭 | R/W | 0x0 |
| 11    | int_remap_en      | <b>中断入口地址重映射使能</b><br>0x0: EFLASH<br>0x1: SRAM                                    | R/W | 0x0 |
| 10    | nmi_inv_sel       | <b>NMI Pin 检测信号反转配置</b><br>0x0: 高电平触发 NMI<br>0x1: 低电平触发 NMI                       | R/W | 0x0 |
| 9     | cp_mode_sysclk_en | <b>CP 模式下切换系统时钟</b><br>0x0: 切换<br>0x1: 保持 ate-clk                                 | R/W | 0x1 |
| 8     | swd_en            | <b>SWD 使能</b><br>0x0: 关闭<br>0x1: 打开                                               | R/W | 0x1 |
| 7     | lvdvcc_wkup_en    | <b>VCC LVD 唤醒使能</b><br>0x0: 关闭<br>0x1: 打开                                         | R/W | 0x0 |
| 6     | clk_test_oe       | <b>内部时钟输出到 PA0</b><br>0x0: 关闭<br>0x1: 打开                                          | R/W | 0x0 |
| 5     | sys_err_resp_en   | <b>系统总线访问内存时，异常响应反馈使能</b><br>0x0: 关闭<br>0x1: 打开                                   | R/W | 0x0 |
| 4     | sys_err_int_en    | <b>系统总线访问出内存异常时，触发 NMI 中断</b><br>0x0: 关闭<br>0x1: 打开                               | R/W | 0x0 |
| 3     | hosc_loss_nmi_en  | <b>监控 XOSC 丢失触发 NMI 中断</b><br>0x0: 关闭<br>0x1: 打开                                  | R/W | 0x0 |
| 2     | rxev_enable       | <b>启用 PA1 作为 CPU 的接收事件</b><br>0x0: 关闭<br>0x1: 打开                                  | R/W | 0x0 |
| 1     | nmi_int_enable    | <b>开启 PA0 作为 CPU 的外部 NMI 输入</b><br>0x0: 关闭<br>0x1: 打开                             | R/W | 0x0 |
| 0     | lockup_enable     | <b>使能系统锁定触发系统复位</b><br>0x0: 关闭<br>0x1: 打开                                         | R/W | 0x0 |

#### 6.4.3.4. SYS\_CON2

| Bit(s) | Name      | Description                               | R/W | Reset |
|--------|-----------|-------------------------------------------|-----|-------|
| 31:30  | Reserved  | -                                         | -   | -     |
| 29:27  | pe_deb_en | GPIOE debounce 使能<br>对应控制 GPIOE0 ~GPIOE2  | R/W | 0x0   |
| 26:16  | pb_deb_en | GPIOB debounce 使能<br>对应控制 GPIOB0 ~GPIOB10 | R/W | 0x0   |
| 15:0   | pa_deb_en | GPIOA debounce 使能<br>对应控制 GPIOA0 ~GPIOA15 | R/W | 0x0   |

#### 6.4.3.5. SYS\_CON3

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:0   | Reserved | -           | -   | -     |

#### 6.4.3.6. SYS\_CON4

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:0   | Reserved | -           | -   | -     |

#### 6.4.3.7. SYS\_CON5

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:0   | Reserved | -           | -   | -     |

#### 6.4.3.8. SYS\_CON6

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:0   | Reserved | -           | -   | -     |

#### 6.4.3.9. SYS\_CON7

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:0   | Reserved | -           | -   | -     |

#### 6.4.3.10. CLK\_CON0

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:18  | Reserved | -           | R/W | -     |

|       |                 |                                                                                                                |     |     |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------|-----|-----|
| 17:16 | lvd_debclk_sel  | <b>Lvd debounce 时钟选择</b><br>0x0: apb0_clk<br>0x1: HIRC 26M<br>0x2: LIRC 128K<br>0x3: LIRC 128K                 | R/W | 0x0 |
| 15:14 | comp_clk_sel    | <b>比较器时钟选择</b><br>0x0: LIRC 128K<br>0x1: divider output from HIRC 26M<br>0x2: sys_clk<br>0x3: XOSC             | R/W | 0x0 |
| 13:12 | Reserved        | -                                                                                                              | R/W | -   |
| 11:10 | gpioe_dbs_sel   | <b>GPIOE debounce 时钟选择</b><br>0x0: divider output from HIRC 26M<br>0x1: XOSC<br>0x2: sys_clk<br>0x3: LIRC 128K | R/W | 0x0 |
| 9:8   | gpiob_dbs_sel   | <b>GPIOB debounce 时钟选择</b><br>0x0: divider output from HIRC 26M<br>0x1: XOSC<br>0x2: sys_clk<br>0x3: LIRC 128K | R/W | 0x0 |
| 7:6   | gpioa_dbs_sel   | <b>GPIOA debounce 时钟选择</b><br>0x0: divider output from HIRC 26M<br>0x1: XOSC<br>0x2: sys_clk<br>0x3: LIRC 128K | R/W | 0x0 |
| 5     | Reserved        | -                                                                                                              | R/W | -   |
| 4     | pll_refclk_sel  | <b>P11 reference 时钟选择</b><br>0x0: HIRC 26M<br>1:XOSC                                                           | R/W | 0x0 |
| 3:2   | clock_to_io_sel | <b>Output clock 选择</b><br>0x0: sys_clk<br>0x1: HIRC 26M<br>0x2: LIRC 32K<br>0x3: XOSC                          | R/W | 0x0 |
| 1:0   | sysclk_sel      | <b>系统时钟选择</b><br>0x0: LIRC 128K<br>0x1: XOSC<br>0x2: HIRC 26M<br>0x3: pll_clk                                  | R/W | 0x0 |

#### 6.4.3.11. CLK\_CON1

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31     | Reserved | -           | -   | -     |

|       |               |                                                                                                                                                   |     |     |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|
| 30:28 | clk_to_io_div | <b>Clock to IO 分配比</b><br>0x0: divide by 1<br>0x1: divide by 2<br>0x2: divide by 3<br>...<br>0x6: divide by 7<br>0x7: close clock output          | R/W | 0x0 |
| 27:24 | hirc_clk_div  | <b>HIRC 26M clock 分频比</b><br>0x0: divide by 1<br>0x1: divide by 2<br>0x2: divide by 3<br>...<br>0xE: divide by 15<br>0xF: close HIRC divide clock | R/W | 0x0 |
| 23:19 | Reserved      | -                                                                                                                                                 | -   | -   |
| 18:16 | pll_clk_div   | <b>pll clock 分频比</b><br>when n=[1,6], pll_clk divide by n+1<br>when n=7, stoppll_clk<br>n=0 is forbidden                                          | R/W | 0x1 |
| 15:12 | apb1clk_div   | <b>PB1 clock 分频比</b><br>0x0: divide by 1<br>0x1: divide by 2<br>0x2: divide by 3<br>...<br>0xE: divide by 15<br>0xF: close apb1_clk               | R/W | 0x0 |
| 11:8  | apb0clk_div   | <b>APB0 clock 分频比</b><br>0x0: divide by 1<br>0x1: divide by 2<br>0x2: divide by 3<br>...<br>0xE: divide by 15<br>0xF: close apb0_clk              | R/W | 0x0 |
| 7:0   | sysclk_div    | <b>System clock 分频比</b><br>0x0: divide by 1<br>0x1: divide by 2<br>0x2: divide by 3<br>...<br>0xFE: divide by 255<br>0xFF: close sys_clk          | R/W | 0x0 |

#### 6.4.3.12. CLK\_CON2

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31     | reserved | -           | -   | -     |

|       |                   |                                                                      |     |     |
|-------|-------------------|----------------------------------------------------------------------|-----|-----|
| 30    | clk_source_en_bps | <b>p11_clk and xosc clock glitch free? ? ?</b><br>0x0: 打开<br>0x1: 关闭 | R/W | 0x1 |
| 29    | cp_clk_en         | <b>CP 模式使能 CPU 时钟</b><br>0x0: 关闭<br>0x1: 打开                          | R/W | 0x0 |
| 28    | test_clk_en       | <b>ATE 时钟输出使能</b><br>0x0: 关闭<br>0x1: 打开                              | R/W | 0x0 |
| 27    | comp_clk_en       | <b>比较器时钟使能</b><br>0x0: 关闭<br>0x1: 打开                                 | R/W | 0x1 |
| 26    | Reserved          | -                                                                    | -   | -   |
| 25    | crc_clk_en        | <b>CRC 时钟使能</b><br>0x0: 关闭<br>0x1: 打开                                | R/W | 0x1 |
| 24    | eflash_mem_clk_en | <b>eflash erase/program 时钟使能</b><br>0x0: 关闭<br>0x1: 打开               | R/W | 0x1 |
| 23    | Reserved          | -                                                                    | -   | -   |
| 22    | hwdiv_clk_en      | <b>硬件除法器时钟使能</b><br>0x0: 关闭<br>0x1: 打开                               | R/W | 0x0 |
| 21:19 | Reserved          | -                                                                    | -   | -   |
| 18    | uart1_clk_en      | <b>UART1 时钟使能</b><br>0x0: 关闭<br>0x1: 打开                              | R/W | 0x1 |
| 17    | uart0_clk_en      | <b>UART0 时钟使能</b><br>0x0: 关闭<br>0x1: 打开                              | R/W | 0x1 |
| 16    | spi1_clk_en       | <b>SPI1 时钟使能</b><br>0x0: 关闭<br>0x1: 打开                               | R/W | 0x1 |
| 15    | spi0_clk_en       | <b>SPI0 时钟使能</b><br>0x0: 关闭<br>0x1: 打开                               | R/W | 0x1 |
| 14    | epwm_clk_en       | <b>EPWM 时钟使能</b><br>0x0: 关闭<br>0x1: 打开                               | R/W | 0x1 |
| 13    | timer5_clk_en     | <b>TIMER5 时钟使能</b><br>0x0: 关闭<br>0x1: 打开                             | R/W | 0x1 |
| 12    | timer3_clk_en     | <b>TIMER3 时钟使能</b><br>0x0: 关闭<br>0x1: 打开                             | R/W | 0x1 |

|     |                |                                           |     |     |
|-----|----------------|-------------------------------------------|-----|-----|
| 11  | timer2_clk_en  | <b>TIMER2 时钟使能</b><br>0x0: 关闭<br>0x1: 打开  | R/W | 0x1 |
| 10  | timer1_clk_en  | <b>TIMER1 时钟使能</b><br>0x0: 关闭<br>0x1: 打开  | R/W | 0x1 |
| 9   | timer0_clk_en  | <b>TIMERO 时钟使能</b><br>0x0: 关闭<br>0x1: 打开  | R/W | 0x1 |
| 8   | wdt_clk_en     | <b>WDT 时钟使能</b><br>0x0: 关闭<br>0x1: 打开     | R/W | 0x1 |
| 7   | wdt_sys_clk_en | <b>WDT sys 时钟使能</b><br>0x0: 关闭<br>0x1: 打开 | R/W | 0x1 |
| 6   | timer4_clk_en  | <b>TIMER4 时钟使能</b><br>0x0: 关闭<br>0x1: 打开  | R/W | 0x1 |
| 5:3 | Reserved       | -                                         | -   | -   |
| 2   | sram0_clk_en   | <b>SRAM0 时钟使能</b><br>0x0: 关闭<br>0x1: 打开   | R/W | 0x1 |
| 1   | ahb1_clk_en    | <b>AHB1 时钟使能</b><br>0x0: 关闭<br>0x1: 打开    | R/W | 0x1 |
| 0   | ahb0_clk_en    | <b>AHB0 时钟使能</b><br>0x0: 关闭<br>0x1: 打开    | R/W | 0x1 |

#### 6.4.3.13. CLK\_CON3

| Bit(s) | Name           | Description                                           | R/W | Reset |
|--------|----------------|-------------------------------------------------------|-----|-------|
| 31     | hrcosc_en_flag | <b>HIRC 26M 工作状态</b><br>0x0: not ready<br>0x1: ready  | RO  | 0x1   |
| 30:29  | Reserved       | -                                                     | -   | -     |
| 28     | hrcosc_vtest2  | <b>VDD 测试使能</b><br>输出 VTSOUT<br>0x0: 关闭<br>0x1: 打开    | R/W | 0x0   |
| 27     | hrcosc_vtest1  | <b>VDDOSC 测试使能</b><br>输出 VTSOUT<br>0x0: 关闭<br>0x1: 打开 | R/W | 0x0   |
| 26     | hrcosc_vsel    | <b>LDO 参考选择</b>                                       | R/W | 0x0   |

|       |             |                                                           |     |      |
|-------|-------------|-----------------------------------------------------------|-----|------|
|       |             | 0x0: Voltage bias<br>0x1: Current                         |     |      |
| 25:19 | hrcosc_sc   | <b>HRCOSC 频率控制</b><br>0x0: lowest<br>...<br>0x7F: highest | R/W | 0x0  |
| 18    | hrcosc_ldos | <b>RCOSC LDO 电压选择</b><br>0x0: 1.5v<br>0x1: 1.6v           | R/W | 0x0  |
| 17    | hrcosc_en   | <b>RCOSC 使能</b><br>0x0: disable<br>0x1: enable            | R/W | 0x1  |
| 16:15 | hxosc_fbres |                                                           | R/W | 0x3  |
| 14:10 | hxosc_dr    |                                                           | R/W | 0x10 |
| 9:6   | hxosc_cto   |                                                           | R/W | 0x0  |
| 5:2   | hxosc_cti   |                                                           | R/W | 0x0  |
| 1     | hxosc_hy    |                                                           | R/W | 0x1  |
| 0     | hxosc_en    | <b>XOSC 使能</b><br>0x0: 关闭<br>0x1: 打开                      | R/W | 0x0  |

#### 6.4.3.14. CLK\_CON4

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:0   | Reserved | -           | -   | -     |

#### 6.4.3.15. CLK\_CON5

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:0   | Reserved | -           | -   | -     |

#### 6.4.3.16. CLK\_CON6

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:0   | Reserved | -           | -   | -     |

#### 6.4.3.17. CLK\_CON7

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:0   | Reserved | -           | -   | -     |

#### 6.4.3.18. HOSC\_MNT

| Bit(s) | Name              | Description                                                                       | R/W | Reset  |
|--------|-------------------|-----------------------------------------------------------------------------------|-----|--------|
| 31:16  | high_limit        | XOSC 工作上限限制                                                                       | R/W | 0x1450 |
| 15     | hosc_mnt_en       | XOSC 监控功能使能<br>0x0: 关闭<br>0x1: 打开                                                 | R/W | 0x0    |
| 14     | hosc_loss_pending | 读取寄存器<br>0x0: 正常状态<br>0x1: 挂起, 表示外部 xosc 失败<br>写寄存器<br>0x0: 清除 pending<br>0x1: 无效 | R/W | 0x0    |
| 13     | hosc_loss_sw_en   | 当检测到外部 osc 故障时, 硬件自动将 osc 时钟从 xosc 切换到 HIRC<br>0x0: 关闭<br>0x1: 打开                 | R/W | 0x0    |
| 12:0   | low_limit         | XOSC 工作下限限制                                                                       | R/W | 0xA7   |

#### 6.4.3.19. SYS\_ERR

| Bit(s) | Name     | Description                                         | R/W | Reset |
|--------|----------|-----------------------------------------------------|-----|-------|
| 31:1   | Reserved | -                                                   | -   | -     |
| 1      | clk_err  | 时钟异常标志<br>0x0: 工作正常<br>0x1: 时钟使用错误时, 此位可由硬件设置, 软件清除 | R/W | 0     |
| 0      | sys_err0 | 系统访问异常<br>如果设置 sys_err_int_en, 这个挂起会导致 NMI 中断       | R/W | 0     |

| clk_err 触发情况                     |              |              |              |
|----------------------------------|--------------|--------------|--------------|
|                                  | lirc disable | hirc disable | xosc disable |
| sys_clk_sel_lirc                 | √            |              |              |
| sys_clk_sel_hirc                 |              | √            |              |
| sys_clk_sel_xosc                 |              |              | √            |
| sys_clk_sel_pll&pll_ref_sel_lirc |              |              |              |
| sys_clk_sel_pll&pll_ref_sel_hirc |              | √            |              |
| sys_clk_sel_pll&pll_ref_sel_xosc |              |              | √            |

#### 6.4.3.20. WKUP\_CON

| Bit(s) | Name      | Description                                                                                    | R/W | Reset |
|--------|-----------|------------------------------------------------------------------------------------------------|-----|-------|
| 31:1   | Reserved  | -                                                                                              | -   | -     |
| 29:24  | wkup_pnd  | <b>Wakeup IO 的边沿检测触发</b><br>0x0: 无触发<br>0x1: 已触发<br>对应关系:<br>BIT24->port0、BIT25->port1 以此类推    | RO  | -     |
| 23:22  | Reserved  | -                                                                                              | -   | -     |
| 21:16  | clr_pnd   | <b>Wakeup pending 清除</b><br>写 1 清除                                                             | WO  | -     |
| 15:14  | Reserved  | -                                                                                              | -   | -     |
| 13:8   | wkup_edge | <b>Wakeup 的边沿唤醒选择</b><br>0x0: 上升沿触发<br>0x1: 下降沿触发                                              | R/W | 0x0   |
| 7:6    | Reserved  | -                                                                                              | -   | -     |
| 5:0    | wkup_en   | <b>Wakeup 使能</b><br>0x0: 关闭<br>0x1: 打开<br>BIT0~BIT3: 外部 GPIO 唤醒<br>BIT4: 比较器唤醒<br>BIT5: LVD 唤醒 | R/W | 0x0   |

#### 6.4.3.21. LP\_CON

| Bit(s) | Name             | Description                                                | R/W | Reset |
|--------|------------------|------------------------------------------------------------|-----|-------|
| 31:9   | Reserved         | -                                                          | -   | -     |
| 8      | lp_mode          | <b>LP 使能</b><br>0x0: 关闭<br>0x1: 打开                         | 0x0 | R/W   |
| 7      | lp_mode_auto_en  | <b>Sleep 模式下自动使能 LP 模式</b><br>0x0: 关闭<br>0x1: 打开           | 0x0 | R/W   |
| 6      | hirc_auto_enable | <b>XOSC 检测出现异常时, 自动使能并切换 HIRC26M</b><br>0x0: 关闭<br>0x1: 打开 | 0x0 | R/W   |
| 5      | rc32k_soft_en    | <b>LIRC 使能</b><br>0x0: 关闭<br>0x1: 打开                       | 0x1 | R/W   |
| 4      | rc32k_auto_dis   | <b>进入 sleep 模式自动关闭 LIRC</b><br>0x0: 关闭<br>0x1: 打开          | 0x0 | R/W   |
| 3      | hirc_auto_dis    | <b>进入 sleep/stop 模式自动关闭 LIRC</b><br>0x0: 关闭                | 0x0 | R/W   |

|   |                |                                                 |     |     |
|---|----------------|-------------------------------------------------|-----|-----|
|   |                | 0x1: 打开                                         |     |     |
| 2 | sram0_auto_dis | 进入 sleep/stop 模式自动关闭 SRAM<br>0x0: 关闭<br>0x1: 打开 | 0x0 | R/W |
| 1 | stopclk        | 进入 stop 模式<br>0x0: 关闭<br>0x1: 打开                | 0x0 | R/W |
| 0 | sleep          | 进入 sleep 模式<br>0x0: 关闭<br>0x1: 打开               | 0x0 | R/W |

#### 6.4.3.22. MBIST\_CON

| Bit(s) | Name              | Description                                                         | R/W | Reset |
|--------|-------------------|---------------------------------------------------------------------|-----|-------|
| 31:21  | Reserved          | -                                                                   | -   | -     |
| 20     | mbist_fail_h      | <b>MBIST 异常标志</b><br>读操作:<br>0x1: MBIST 异常<br>写操作:<br>0x1: 清除异常标志   | R/W | 0x0   |
| 19     | mbist_tst_done    | <b>MBIST 完成标志</b><br>读操作:<br>0x1: MBIST 测试完成<br>写操作:<br>0x1: 清除完成标志 | R/W | 0x0   |
| 18     | mbist_clk_en      | <b>MBIST 时钟使能</b><br>0x0: 关闭<br>0x1: 打开                             | R/W | 0x0   |
| 17:12  | Reserved          | -                                                                   | -   | -     |
| 11     | mbist_rf1p_debugz | <b>MBIST rf1p 调试使能</b><br>0x0: 关闭<br>0x1: 打开                        | R/W | 0x0   |
| 10     | mbist_rf1p_hold_l | <b>MBIST rf1p 调试使能</b><br>0x0: 关闭<br>0x1: 打开                        | R/W | 0x0   |
| 9      | mbist_rf1p_test_h | <b>MBIST rf1p 调试使能</b><br>0x0: 关闭<br>0x1: 打开                        | R/W | 0x0   |
| 8:0    | Reserved          | -                                                                   | -   | -     |

#### 6.4.3.23. MBIST\_MISR

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:0   | Reserved | -           | -   | -     |

#### 6.4.3.24. MODE

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:0   | Reserved | -           | -   | -     |

#### 6.4.3.25. PMU\_CON

| Bit(s) | Name     | Description                                                                                                                                                                                                                                           | R/W | Reset |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:23  | Reserved | -                                                                                                                                                                                                                                                     | -   | -     |
| 22:20  | dset     | -                                                                                                                                                                                                                                                     | R/W | 0x4   |
| 19:16  | pdcore   | VDD 下拉信号选择<br>0x0: 304pa<br>0x1: 68ua<br>0x2: 263ua<br>0x3: 330ua<br>0x4: 1.31ma<br>0x5: 1.38ma<br>0x6: 1.57ma<br>0x7: 1.64ma<br>0x8: 5.24ma<br>0x9: 5.31ma<br>0xA: 5.51ma<br>0xB: 5.57ma<br>0xC: 6.56ma<br>0xD: 6.62ma<br>0xE: 6.81ma<br>0xF: 6.89ma | R/W | 0x4   |
| 15:12  | lpset    | LP 模式关闭模块<br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                       | R/W | 0x0   |
| 11     | lpen     | LP 模式使能<br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                         | R/W | 0x0   |
| 10     | vrefaen  | VREF 使能<br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                         | R/W | 0x1   |
| 9      | tsensen  | 内部温度传感器<br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                         | R/W | 0x0   |
| 8      | irefen   | 偏置电流使能<br>低功率模式时需要设置为 0<br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                         | R/W | 0x1   |

|     |        |                                                                                                                                                                                                             |     |     |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|
| 7   | bor5en | VCC POR 使能<br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                            | R/W | 0x1 |
| 6:3 | vddset | VDD 电压档位选择<br>0x0: 1.2v<br>0x1: 1.25v<br>0x2: 1.3v<br>0x3: 1.35v<br>0x4: 1.4v<br>0x5: 1.45v<br>0x6: 1.5v<br>0x7: 1.55v<br>0x8: 1.6v<br>0x9: 1.65v<br>0xA: 1.7v<br>0xB: 1.75v<br>0xC: 1.8v<br>0xD~0xF: 1.85v | R/W | 0x6 |
| 2:0 | vbgset | BGR 电压档位选择<br>0x0: 1.118v<br>0x1: 1.145v<br>0x2: 1.174v<br>0x3: 1.206v<br>0x4: 1.230v<br>0x5: 1.259v<br>0x6: 1.287v<br>0x7: 1.287v                                                                          | R/W | 0x3 |

注: vbgset/ vddset 将在上电过程中加载 trim 值, 所以他们读回来可能不是默认值参考上表。

#### 6.4.3.26. RPCON

| Bit(s) | Name                 | Description                    | R/W | Reset |
|--------|----------------------|--------------------------------|-----|-------|
| 31:20  | Reserved             |                                | -   | -     |
| 19     | uart0_reset_clr      | Uart0 复位 pending 清除<br>写 1 清除  | WO  | 0     |
| 18     | lockup_reset_clr     | Lockup 复位 pending 清除<br>写 1 清除 | WO  | 0     |
| 17     | soft_reset_clr       | 软件复位 pending 清除<br>写 1 清除      | WO  | 0     |
| 16     | sleep_sta_clr        | Sleep pending 清除<br>写 1 清除     | WO  | 0     |
| 15:4   | Reserved             |                                | -   | -     |
| 3      | uart0_update_pending | Uart0 复位 pending               | RO  | 0     |
| 2      | lock_reset_pending   | Lockup 复位 pending              | RO  | -     |
| 1      | soft_reset_pending   | 软件复位 pending                   | RW  | -     |

|   |               |               |    |   |
|---|---------------|---------------|----|---|
|   |               | 写 1 复位        |    |   |
| 0 | sleep_pending | Sleep pending | R0 | - |

#### 6.4.3.27. AMP\_CON0

| Bit(s) | Name     | Description                                                                                                    | R/W | Reset |
|--------|----------|----------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:27  | qcsel3   | <b>AMP3 filter cap 选择</b><br>0x01: 300fp<br>0x02: 300fp<br>0x04: 400fp<br>0x08: 400fp<br>0x10: 600fp           | R/W | 0x1   |
| 26:24  | gainsel3 | <b>AMP3 gain 选择</b><br>0x0: x4<br>0x1: x6<br>0x2: x8<br>0x3: x10<br>0x4: x12<br>0x5~0x7: disable feedback loop | R/W | 0x2   |
| 23:19  | qcsel2   | <b>AMP2 filter cap 选择</b><br>0x01: 300fp<br>0x02: 300fp<br>0x04: 400fp<br>0x08: 400fp<br>0x10: 600fp           | R/W | 0x1   |
| 18:16  | gainsel2 | <b>AMP2 gain 选择</b><br>0x0: x4<br>0x1: x6<br>0x2: x8<br>0x3: x10<br>0x4: x12<br>0x5~0x7: disable feedback loop | R/W | 0x2   |
| 15:11  | qcself   | <b>AMP1 filter cap 选择</b><br>0x01: 300fp<br>0x02: 300fp<br>0x04: 400fp<br>0x08: 400fp<br>0x10: 600fp           | R/W | 0x1   |
| 10:8   | gainsell | <b>AMP1 gain 选择</b><br>0x0: x4<br>0x1: x6<br>0x2: x8<br>0x3: x10<br>0x4: x12<br>0x5~0x7: disable feedback loop | R/W | 0x2   |

|   |            |                                         |     |     |
|---|------------|-----------------------------------------|-----|-----|
| 7 | amp1ldo_en | <b>AMP LDO 使能</b><br>0x0: 关闭<br>0x1: 打开 | R/W | 0x0 |
| 6 | bias_en    | <b>BIAS 使能</b><br>0x0: 关闭<br>0x1: 打开    | R/W | 0x0 |
| 5 | biasadd_en | <b>BIASADD 使能</b><br>0x0: 关闭<br>0x1: 打开 | R/W | 0x0 |
| 4 | rcchan_en  | <b>RCCCHAN 使能</b><br>0x0: 关闭<br>0x1: 打开 | R/W | 0x0 |
| 3 | vcmbuff_en | <b>VCMBUFF 使能</b><br>0x0: 关闭<br>0x1: 打开 | R/W | 0x0 |
| 2 | amp3_en    | <b>AMP3 使能</b><br>0x0: 关闭<br>0x1: 打开    | R/W | 0x0 |
| 1 | amp2_en    | <b>AMP2 使能</b><br>0x0: 关闭<br>0x1: 打开    | R/W | 0x0 |
| 0 | amp1_en    | <b>AMP1 使能</b><br>0x0: 关闭<br>0x1: 打开    | R/W | 0x0 |

#### 6.4.3.28. AMP\_CON1

| Bit(s) | Name        | Description                                                                  | R/W | Reset |
|--------|-------------|------------------------------------------------------------------------------|-----|-------|
| 31:13  | Reserved    | -                                                                            | -   | -     |
| 12     | vout2pad_en | <b>AMP2 输出到 PB2 使能</b><br>0x0: 关闭<br>0x1: 打开                                 | R/W | 0x0   |
| 11     | vout1pad_en | <b>AMP1 输出到 PB1 使能</b><br>0x0: 关闭<br>0x1: 打开                                 | R/W | 0x0   |
| 10:9   | rcrsel      | <b>AMP3 RC 滤波电阻选择</b><br>0x0: 1K<br>0x1: 10K<br>0x2: 50K<br>0x3: 100K        | R/W | 0x0   |
| 8:6    | restrim3    | <b>AMP3 feedback 配置</b><br>0x0: 1.17X<br>0x1: 1.05X<br>0x2: 1X<br>0x3: 0.95X | R/W | 0x2   |

|     |          |                                                                                                                                |     |     |
|-----|----------|--------------------------------------------------------------------------------------------------------------------------------|-----|-----|
|     |          | 0x4: 0.87X<br>0x5 – 0x7: disable feedback loop                                                                                 |     |     |
| 5:3 | restrim2 | <b>AMP2 feedback 配置</b><br>0x0: 1.17X<br>0x1: 1.05X<br>0x2: 1X<br>0x3: 0.95X<br>0x4: 0.87X<br>0x5 – 0x7: disable feedback loop | R/W | 0x2 |
| 2:0 | restrim1 | <b>AMP1 feedback 配置</b><br>0x0: 1.17X<br>0x1: 1.05X<br>0x2: 1X<br>0x3: 0.95X<br>0x4: 0.87X<br>0x5 – 0x7: disable feedback loop | R/W | 0x2 |

#### 6.4.3.29. PMUBK

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                                 | R/W | Reset |
|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | Reserved  | -                                                                                                                                                                                                                                                                           | -   | -     |
| 15     | lpen_bk   | <b>backup register of lpen</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                        | R/W | 0x1   |
| 14:11  | lpset_bk  | <b>backup register of lpset</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                       | R/W | 0xF   |
| 10:7   | pdcore_bk | <b>backup register of pdcore</b><br>0x0: 304pa<br>0x1: 68ua<br>0x2: 263ua<br>0x3: 330ua<br>0x4: 1.31ma<br>0x5: 1.38ma<br>0x6: 1.57ma<br>0x7: 1.64ma<br>0x8: 5.24ma<br>0x9: 5.31ma<br>0xA: 5.51ma<br>0xB: 5.57ma<br>0xC: 6.56ma<br>0xD: 6.62ma<br>0xE: 6.81ma<br>0xF: 6.89ma | R/W | 0x0   |
| 6:3    | vddset_bk | <b>backup register of VDD</b>                                                                                                                                                                                                                                               |     | 0x6   |

|     |           |                                                                                                                                                                                                 |     |     |
|-----|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|
|     |           | 0x0: 1.2v<br>0x1: 1.25v<br>0x2: 1.3v<br>0x3: 1.35v<br>0x4: 1.4v<br>0x5: 1.45v<br>0x6: 1.5v<br>0x7: 1.55v<br>0x8: 1.6v<br>0x9: 1.65v<br>0xA: 1.7v<br>0xB: 1.75v<br>0xC: 1.8v<br>0xD – 0xF: 1.85v |     |     |
| 2:0 | vbgset_bk | <b>backup register of BGR</b><br>0x0: 1.118v<br>0x1: 1.145v<br>0x2: 1.174v<br>0x3: 1.206v<br>0x4: 1.230v<br>0x5: 1.259v<br>0x6: 1.287v<br>0x7: 1.287v                                           | R/W | 0x3 |

#### 6.4.3.30. 芯片信息 0 (0x1FF00600)

| Bit(s) | Name | Description | R/W | Reset       |
|--------|------|-------------|-----|-------------|
| 31:0   | UID0 | UID 信息 0    | RO  | 0xFFFF FFFF |

#### 6.4.3.31. 芯片信息 1 (0x1FF00604)

| Bit(s) | Name | Description | R/W | Reset       |
|--------|------|-------------|-----|-------------|
| 31:0   | UID1 | UID 信息 1    | RO  | 0xFFFF FFFF |

#### 6.4.3.32. 芯片信息 2 (0x1FF00608)

| Bit(s) | Name | Description | R/W | Reset       |
|--------|------|-------------|-----|-------------|
| 31:0   | UID2 | UID 信息 2    | RO  | 0xFFFF FFFF |

## 7. GPIO

每组 GPIO 端口有四个 32 位配置寄存器(GPIOx\_MODER,GPIOx\_OTYPER, GPIOx\_OSPEEDR and GPIOx\_PUPDR), 两个 32 位数据寄存器(GPIOx\_IDR and GPIOx\_ODR), 一个 32 位置位/复位寄存器(GPIOx\_BSRR)和一个 32 位翻转寄存器(GPIOx\_TGL)。另外, 所有 GPIO 有一个 32 位锁定寄存器(GPIOx\_LCKR) 和两个复用功能选择寄存器 (GPIOx\_AFRH and GPIOx\_AFRL)。

### 7.1. GPIO 主要特征

- 输出状态: 推挽或开漏+上下拉
- 输出寄存器状态值 (GPIOx\_ODR) 或者外设功能输出 (alternate function output)
- 每个 IO 驱动能力可配置
- 输入状态: 浮空、上下拉、模拟
- 输入数据到数据寄存器(GPIOx\_IDR) 或外设 (alternate function input)
- 独立置位/复位/翻转 IO 状态 (GPIOx\_BSRR, GPIOx\_TGL)
- 通过加锁配置 (GPIOx\_LCKR) 锁定 IO 状态
- 模拟功能
- 复用功能

### 7.2. GPIO 功能描述

GPIO 的每一个端口可以通过软件独立配置成下面状态:

- 输入浮空
- 输入上拉
- 输入下拉
- 模拟功能
- 开漏输出 (上拉或下拉)
- 推挽输出 (上拉或下拉)
- 复用功能 (开漏或推挽、上拉或下拉)

表 8-1 GPIO 的模式配置表

| MODE | OTYPE(i) | OSPEED(i)  | PUPD(i) |   | IO configuration |              |
|------|----------|------------|---------|---|------------------|--------------|
| 01   | 0        | SPEED[1:0] | 0       | 0 | GP output        | PP           |
|      | 0        |            | 0       | 1 | Reserved         |              |
|      | 0        |            | 1       | 0 |                  |              |
|      | 0        |            | 1       | 1 | Reserved         |              |
|      | 1        |            | 0       | 0 | GP output        | OD           |
|      | 1        |            | 0       | 1 | GP output        | OD+PU        |
|      | 1        |            | 1       | 0 | Reserved         |              |
|      | 1        |            | 1       | 1 |                  |              |
| 10   | 0        | SPEED[1:0] | 0       | 0 | AF               | PP           |
|      | 0        |            | 0       | 1 | Reserved         |              |
|      | 0        |            | 1       | 0 |                  |              |
|      | 0        |            | 1       | 1 | Reserved         |              |
|      | 1        |            | 0       | 0 | AF               | OD           |
|      | 1        |            | 0       | 1 | AF               | OD+PU        |
|      | 1        |            | 1       | 0 | Reserved         |              |
|      | 1        |            | 1       | 1 |                  |              |
| 00   | x        | x          | x       | 0 | 0                | Input        |
|      | x        | x          | x       | 0 | 1                | Input        |
|      | x        | x          | x       | 1 | 0                | Input        |
|      | x        | x          | x       | 1 | 1                | Reserved     |
| 11   | x        | x          | x       | 0 | 0                | Input/Output |
|      | x        | x          | x       | 0 | 1                | Reserved     |
|      | x        | x          | x       | 1 | 0                |              |
|      | x        | x          | x       | 1 | 1                |              |

GP = generate-purpose, PP = push-pull, PU = pull-up, PD = pull-down, OD = open-drain, AF = alternate function.

### 7.2.1. 通用 IO (GPIO)

复位期间和刚复位后，复用功能未开启，I/O 端口被配置成浮空输入模式。DBG\_CLK 这个 I/O 可以被配置成上拉或下拉使能，依据客户自己的配置。

当作为输出配置时，写到输出数据寄存器上的值 (GPIOx\_ODR) 输出到相应的 I/O 引脚。可以以推挽或开漏模式使用输出驱动器。

输入数据寄存器 (GPIOx\_IDR) 在每个 AHB 时钟周期捕捉 I/O 引脚上的数据。

所有 GPIO 引脚有一个内部弱上拉和弱下拉，当配置为输入时，它们可以被激活也可以被断开。

### 7.2.2. 单独的位操作

当对 GPIOx\_ODR 的个别位编程时，软件不需要禁止中断：在单次 AHB 写操作里，可以只更改一个或多个位。只需要通过对“置位/复位寄存器”（GPIOx\_BSR）或“取反寄存器”（GPIOx\_TGL）中想要更改的位写“1”来实现。没被选择的位将不被更改。

### 7.2.3. 复用功能 (AF)

芯片 IO 引脚通过多路选择器连接到片内外设，每个 IO 上同一时刻只能选通一个复用功能。每个 IO 引脚有一个 4 输入的多路选择器连接到复用功能 (AF0~AF3)，通过配置 GPIOx\_AFRH/L 选择输入功能。如果把端口配置成复用输出功能，则引脚和输出寄存器断开，并和片上外设的输出信号连接。如果软件把一个 GPIO 脚配置成复用输出功能，但是外设没有被激活，它的输出将不确定。

### 7.2.4. GPIO 锁定机制

锁定机制允许在 GPIO 控制寄存器 GPIOx\_LCKR 上执行一串锁定程序，然后把 GPIO 的状态锁定，一旦 GPIO 状态被锁定，将不可改变，直到 CPU 复位。被锁定的寄存器有 (GPIOx\_MODER、GPIOx\_OTYPER, GPIOx\_OSPEEDR、GPIOx\_PUPDR、GPIOx\_AFRL、GPIOx\_AFRH)。

锁定序列参考 GPIOx\_LCKR 寄存器描述。

### 7.2.5. 输入配置

当 I/O 端口配置为输入时：

- 输出缓冲器被禁止
- 施密特触发输入被激活

- 根据输入配置（上拉、下拉或浮空）的不同，弱上拉和下拉电阻被连接
- 出现在 I/O 脚上的数据在每个 AHB 时钟被采样到输入数据寄存器
- 对输入数据寄存器的读访问可得到 I/O 状态

### 7.2.6. 输出配置

当 I/O 端口被配置为输出时：

- 输出缓冲器被激活
  - ✓ 开漏模式：输出寄存器上的“0”激活 N-MOS，而输出寄存器上的“1”将端口置于高阻态（P-MOS 从不被激活）。
  - ✓ 推挽模式：输出寄存器上的“0”激活 N-MOS，而输出寄存器上的“1”将激活 P-MOS。
- 施密特触发输入被激活
- 弱上拉和下拉电阻根据配置被激活
- 出现在 I/O 脚上的数据在每个 AHB 时钟被采样到输入数据寄存器
- 在开漏模式时，对输入数据寄存器的读访问可得到 I/O 状态
- 在推挽模式时，对输出数据寄存器的读访问得到最后一次写的值。

### 7.2.7. 模拟输入配置

当 I/O 端口被配置为模拟输入配置时：

- 输出缓冲器被禁止；
- 禁止施密特触发输入，实现了每个模拟 I/O 引脚上的零消耗。施密特触发输出值被强制为“0”；
- 弱上拉和下拉电阻被禁止；
- 读取输入数据寄存器时数值为“0”。

## 7.3. 寄存器

### 7.3.1. 寄存器地址

| Name  | Base Address | Description |
|-------|--------------|-------------|
| GPIOA | 0x40020B00   | GPIOA 基地址   |
| GPIOB | 0x40020C00   | GPIOB 基地址   |
| GPIOC | 0x40020F00   | GPIOE 基地址   |

### 7.3.2. 寄存器列表

| Offset Address | Name          | Description                   |
|----------------|---------------|-------------------------------|
| 0x0000         | GPIOA_MODE    | GPIOA 模式选择寄存器                 |
| 0x0004         | GPIOA_OTYPE   | GPIOA 输出方式寄存器                 |
| 0x0008         | GPIOA_OSPEEDL | GPIOA 驱动能力配置寄存器 L             |
| 0x000c         | GPIOA_OSPEEDH | GPIOA 驱动能力配置寄存器 H             |
| 0x0010         | GPIOA_PUPD    | GPIOA 上下拉配置寄存器                |
| 0x0014         | GPIOA_IDR     | GPIOA 输入寄存器                   |
| 0x0018         | GPIOA_ODR     | GPIOA 输出寄存器                   |
| 0x001c         | GPIOA_BSR     | GPIOA BIT Set 和 BIT Reset 寄存器 |
| 0x0020         | GPIOA_LCK     | GPIOA 加锁寄存器                   |
| 0x0024         | GPIOA_AFRL    | GPIOA 多功能配置寄存器 L              |
| 0x0028         | GPIOA_AFRH    | GPIOA 多功能配置寄存器 H              |
| 0x002c         | GPIOA_TGL     | GPIOA 翻转寄存器                   |
| 0x0030         | GPIOA_IMK     | GPIOA 中断寄存器                   |

| Offset Address | Name          | Description       |
|----------------|---------------|-------------------|
| 0x0000         | GPIOB_MODE    | GPIOB 模式选择寄存器     |
| 0x0004         | GPIOB_OTYPE   | GPIOB 输出方式寄存器     |
| 0x0008         | GPIOB_OSPEEDL | GPIOB 驱动能力配置寄存器 L |

|        |               |                               |
|--------|---------------|-------------------------------|
| 0x000c | GPIOB_OSPEEDH | GPIOB 驱动能力配置寄存器 H             |
| 0x0010 | GPIOB_PUPD    | GPIOB 上下拉配置寄存器                |
| 0x0014 | GPIOB_IDR     | GPIOB 输入寄存器                   |
| 0x0018 | GPIOB_ODR     | GPIOB 输出寄存器                   |
| 0x001c | GPIOB_BSR     | GPIOB BIT Set 和 BIT Reset 寄存器 |
| 0x0020 | GPIOB_LCK     | GPIOB 加锁寄存器                   |
| 0x0024 | GPIOB_AFRL    | GPIOB 多功能配置寄存器 L              |
| 0x0028 | GPIOB_AFRH    | GPIOB 多功能配置寄存器 H              |
| 0x002c | GPIOB_TGL     | GPIOB 翻转寄存器                   |
| 0x0030 | GPIOB_IMK     | GPIOB 中断寄存器                   |

| Offset Address | Name          | Description                   |
|----------------|---------------|-------------------------------|
| 0x0000         | GPIOE_MODE    | GPIOE 模式选择寄存器                 |
| 0x0004         | GPIOE_OTYPE   | GPIOE 输出方式寄存器                 |
| 0x0008         | GPIOE_OSPEEDL | GPIOE 驱动能力配置寄存器 L             |
| 0x000c         | GPIOE_OSPEEDH | GPIOE 驱动能力配置寄存器 H             |
| 0x0010         | GPIOE_PUPD    | GPIOE 上下拉配置寄存器                |
| 0x0014         | GPIOE_IDR     | GPIOE 输入寄存器                   |
| 0x0018         | GPIOE_ODR     | GPIOE 输出寄存器                   |
| 0x001c         | GPIOE_BSR     | GPIOE BIT Set 和 BIT Reset 寄存器 |
| 0x0020         | GPIOE_LCK     | GPIOE 加锁寄存器                   |
| 0x0024         | GPIOE_AFRL    | GPIOE 多功能配置寄存器 L              |
| 0x0028         | GPIOE_AFRH    | GPIOE 多功能配置寄存器 H              |
| 0x002c         | GPIOE_TGL     | GPIOE 翻转寄存器                   |
| 0x0030         | GPIOE_IMK     | GPIOE 中断寄存器                   |

### 7.3.3. 寄存器详细定义

#### 7.3.3.1. GPIOx\_MODE

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|--------|------|-------------|-----|-------|

|       |         |                                                                             |    |     |
|-------|---------|-----------------------------------------------------------------------------|----|-----|
| 31:30 | MODER15 | <b>GPIOx15 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |
| 29:28 | MODER14 | <b>GPIOx14 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |
| 27:26 | MODER13 | <b>GPIOx13 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |
| 25:24 | MODER12 | <b>GPIOx12 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |
| 23:22 | MODER11 | <b>GPIOx11 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |
| 21:20 | MODER10 | <b>GPIOx10 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |
| 19:18 | MODER9  | <b>GPIOx9 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入  | RW | 0x0 |
| 17:16 | MODER8  | <b>GPIOx8 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入  | RW | 0x0 |
| 15:14 | MODER7  | <b>GPIOx7 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入  | RW | 0x0 |
| 13:12 | MODER6  | <b>GPIOx6 模式选择</b>                                                          | RW | 0x0 |

|       |        |                                                                            |    |     |
|-------|--------|----------------------------------------------------------------------------|----|-----|
|       |        | 0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入                       |    |     |
| 11:10 | MODER5 | <b>GPIOx5 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |
| 9:8   | MODER4 | <b>GPIOx4 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |
| 7:6   | MODER3 | <b>GPIOx3 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |
| 5:4   | MODER2 | <b>GPIOx2 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |
| 3:2   | MODER1 | <b>GPIOx1 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |
| 1:0   | MODERO | <b>GPIOx0 模式选择</b><br>0x0: 输入模式<br>0x1: 输出模式<br>0x2: AF 多功能模式<br>0x3: 模拟输入 | RW | 0x0 |

### 7.3.3.2. GPIOx\_OTYPE

| Bit(s) | Name     | Description                                    | R/W | Reset |
|--------|----------|------------------------------------------------|-----|-------|
| 31:16  | Reserved | -                                              | -   | -     |
| 15     | OT15     | <b>GPIOx15 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出 | RW  | 0x0   |
| 14     | OT14     | <b>GPIOx14 输出的类型</b><br>0x0: 推挽输出              | RW  | 0x0   |

|    |      |                                                |    |     |
|----|------|------------------------------------------------|----|-----|
|    |      | 0x1: 开漏输出                                      |    |     |
| 13 | OT13 | <b>GPIOx13 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出 | RW | 0x0 |
| 12 | OT12 | <b>GPIOx12 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出 | RW | 0x0 |
| 11 | OT11 | <b>GPIOx11 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出 | RW | 0x0 |
| 10 | OT10 | <b>GPIOx10 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出 | RW | 0x0 |
| 9  | OT9  | <b>GPIOx9 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出  | RW | 0x0 |
| 8  | OT8  | <b>GPIOx8 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出  | RW | 0x0 |
| 7  | OT7  | <b>GPIOx7 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出  | RW | 0x0 |
| 6  | OT6  | <b>GPIOx6 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出  | RW | 0x0 |
| 5  | OT5  | <b>GPIOx5 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出  | RW | 0x0 |
| 4  | OT4  | <b>GPIOx4 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出  | RW | 0x0 |
| 3  | OT3  | <b>GPIOx3 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出  | RW | 0x0 |
| 2  | OT2  | <b>GPIOx2 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出  | RW | 0x0 |
| 1  | OT1  | <b>GPIOx1 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出  | RW | 0x0 |
| 0  | OT0  | <b>GPIOx0 输出的类型</b><br>0x0: 推挽输出<br>0x1: 开漏输出  | RW | 0x0 |

### 7.3.3.3. GPIOx\_OSPEEDL

| Bit(s) | Name    | Description                                                                         | R/W | Reset |
|--------|---------|-------------------------------------------------------------------------------------|-----|-------|
| 31:28  | OSPEED7 | <b>GPIOx7 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 27:24  | OSPEED6 | <b>GPIOx6 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 23:20  | OSPEED5 | <b>GPIOx5 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 19:16  | OSPEED4 | <b>GPIOx4 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 15:12  | OSPEED3 | <b>GPIOx3 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 11:8   | OSPEED2 | <b>GPIOx2 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 7:4    | OSPEED1 | <b>GPIOx1 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 3:0    | OSPEED0 | <b>GPIOx0 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |

#### 7.3.3.4. GPIOx\_OSPEEDH

| Bit(s) | Name     | Description                                                                          | R/W | Reset |
|--------|----------|--------------------------------------------------------------------------------------|-----|-------|
| 31:28  | OSPEED15 | <b>GPIOx15 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 27:24  | OSPEED14 | <b>GPIOx14 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 23:20  | OSPEED13 | <b>GPIOx13 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 19:16  | OSPEED12 | <b>GPIOx12 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 15:12  | OSPEED11 | <b>GPIOx11 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 11:8   | OSPEED10 | <b>GPIOx10 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3 | RW  | 0x0   |
| 7:4    | OSPEED9  | <b>GPIOx9 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3  | RW  | 0x0   |
| 3:0    | OSPEED8  | <b>GPIOx8 驱动能力配置</b><br>0x0: low speed<br>0x1: speed1<br>0x2: speed2<br>0x3: speed3  | RW  | 0x0   |

### 7.3.3.5. GOIOx\_PUPD

| Bit(s) | Name | Description                                 | R/W | Reset |
|--------|------|---------------------------------------------|-----|-------|
| 31     | PD15 | GPIOx15 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 30     | PD14 | GPIOx14 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 29     | PD13 | GPIOx13 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 28     | PD12 | GPIOx12 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 27     | PD11 | GPIOx11 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 26     | PD10 | GPIOx10 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 25     | PD9  | GPIOx9 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW  | 0x0   |
| 24     | PD8  | GPIOx8 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW  | 0x0   |
| 23     | PD7  | GPIOx7 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW  | 0x0   |
| 22     | PD6  | GPIOx6 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW  | 0x0   |
| 21     | PD5  | GPIOx5 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW  | 0x0   |
| 20     | PD4  | GPIOx4 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW  | 0x0   |
| 19     | PD3  | GPIOx3 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW  | 0x0   |
| 18     | PD2  | GPIOx2 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW  | 0x0   |
| 17     | PD1  | GPIOx1 下拉电阻 (10K) 选择                        | RW  | 0x0   |

|    |      |                                             |    |     |
|----|------|---------------------------------------------|----|-----|
|    |      | 0x0: 关闭<br>0x1: 打开                          |    |     |
| 16 | PDO  | GPIOx0 下拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 15 | PU15 | GPIOx15 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 14 | PU14 | GPIOx14 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 13 | PU13 | GPIOx13 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 12 | PU12 | GPIOx12 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 11 | PU11 | GPIOx11 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 10 | PU10 | GPIOx10 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 9  | PU9  | GPIOx9 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 8  | PU8  | GPIOx8 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 7  | PU7  | GPIOx7 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 6  | PU6  | GPIOx6 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 5  | PU5  | GPIOx5 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 4  | PU4  | GPIOx4 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 3  | PU3  | GPIOx3 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 2  | PU2  | GPIOx2 上拉电阻 (10K) 选择                        | RW | 0x0 |

|   |     |                                            |    |     |
|---|-----|--------------------------------------------|----|-----|
|   |     | 0x0: 关闭<br>0x1: 打开                         |    |     |
| 1 | PU1 | GPIOx1 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 0 | PU0 | GPIOx0 上拉电阻 (10K) 选择<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

### 7.3.3.6. GPIOx\_IDR

| Bit(s) | Name     | Description    | R/W | Reset |
|--------|----------|----------------|-----|-------|
| 31:16  | Reserved | -              | -   | -     |
| 15     | IDR15    | GPIOx15 输入数据读取 | RO  | 0x0   |
| 14     | IDR14    | GPIOx14 输入数据读取 | RO  | 0x0   |
| 13     | IDR13    | GPIOx13 输入数据读取 | RO  | 0x0   |
| 12     | IDR12    | GPIOx12 输入数据读取 | RO  | 0x0   |
| 11     | IDR11    | GPIOx11 输入数据读取 | RO  | 0x0   |
| 10     | IDR10    | GPIOx10 输入数据读取 | RO  | 0x0   |
| 9      | IDR9     | GPIOx9 输入数据读取  | RO  | 0x0   |
| 8      | IDR8     | GPIOx8 输入数据读取  | RO  | 0x0   |
| 7      | IDR7     | GPIOx7 输入数据读取  | RO  | 0x0   |
| 6      | IDR6     | GPIOx6 输入数据读取  | RO  | 0x0   |
| 5      | IDR5     | GPIOx5 输入数据读取  | RO  | 0x0   |
| 4      | IDR4     | GPIOx4 输入数据读取  | RO  | 0x0   |
| 3      | IDR3     | GPIOx3 输入数据读取  | RO  | 0x0   |
| 2      | IDR2     | GPIOx2 输入数据读取  | RO  | 0x0   |
| 1      | IDR1     | GPIOx1 输入数据读取  | RO  | 0x0   |
| 0      | IDR0     | GPIOx0 输入数据读取  | RO  | 0x0   |

### 7.3.3.7. GPIOx\_ODR

| Bit(s) | Name     | Description   | R/W | Reset |
|--------|----------|---------------|-----|-------|
| 31:16  | Reserved | -             | -   | -     |
| 15     | ODR15    | GPIOx15 输出寄存器 | RW  | 0x0   |
| 14     | ODR14    | GPIOx14 输出寄存器 | RW  | 0x0   |
| 13     | ODR13    | GPIOx13 输出寄存器 | RW  | 0x0   |
| 12     | ODR12    | GPIOx12 输出寄存器 | RW  | 0x0   |
| 11     | ODR11    | GPIOx11 输出寄存器 | RW  | 0x0   |
| 10     | ODR10    | GPIOx10 输出寄存器 | RW  | 0x0   |
| 9      | ODR9     | GPIOx9 输出寄存器  | RW  | 0x0   |
| 8      | ODR8     | GPIOx8 输出寄存器  | RW  | 0x0   |

|   |      |              |    |     |
|---|------|--------------|----|-----|
| 7 | ODR7 | GPIOx7 输出寄存器 | RW | 0x0 |
| 6 | ODR6 | GPIOx6 输出寄存器 | RW | 0x0 |
| 5 | ODR5 | GPIOx5 输出寄存器 | RW | 0x0 |
| 4 | ODR4 | GPIOx4 输出寄存器 | RW | 0x0 |
| 3 | ODR3 | GPIOx3 输出寄存器 | RW | 0x0 |
| 2 | ODR2 | GPIOx2 输出寄存器 | RW | 0x0 |
| 1 | ODR1 | GPIOx1 输出寄存器 | RW | 0x0 |
| 0 | ODR0 | GPIOx0 输出寄存器 | RW | 0x0 |

### 7.3.3.8. GPIOx\_BSR

| Bit(s) | Name | Description                               | R/W | Reset |
|--------|------|-------------------------------------------|-----|-------|
| 31     | BR15 | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 30     | BR14 | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 29     | BR13 | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 28     | BR12 | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 27     | BR11 | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 26     | BR10 | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 25     | BR9  | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 24     | BR8  | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 23     | BR7  | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 22     | BR6  | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 21     | BR5  | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 20     | BR4  | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 19     | BR3  | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 18     | BR2  | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 17     | BR1  | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |
| 16     | BR0  | <b>Bit Reset 配置</b><br>写1有效，有效时，GPIO输出低电平 | WO  | 0x0   |

|    |      |                                              |    |     |
|----|------|----------------------------------------------|----|-----|
| 15 | BS15 | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 14 | BS14 | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 13 | BS13 | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 12 | BS12 | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 11 | BS11 | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 10 | BS10 | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 9  | BS9  | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 8  | BS8  | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 7  | BS7  | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 6  | BS6  | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 5  | BS5  | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 4  | BS4  | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 3  | BS3  | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 2  | BS2  | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 1  | BS1  | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |
| 0  | BS0  | <b>Bit Set 配置</b><br>写 1 有效, 有效时, GPIO 输出高电平 | WO | 0x0 |

### 7.3.3.9. GPIOx\_LCK

| Bit(s) | Name     | Description                               | R/W | Reset |
|--------|----------|-------------------------------------------|-----|-------|
| 31:17  | Reserved | -                                         | -   | -     |
| 16     | LCKEN    | <b>GPIO 加锁有效使能</b><br>0x0: 关闭<br>0x1: 打开  | RW  | 0x0   |
| 15     | LCK15    | <b>GPIOx15 加锁使能</b><br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 14     | LCK14    | <b>GPIOx14 加锁使能</b>                       | RW  | 0x0   |

|    |       |                                           |    |     |
|----|-------|-------------------------------------------|----|-----|
|    |       | 0x0: 关闭<br>0x1: 打开                        |    |     |
| 13 | LCK13 | <b>GPIOx13 加锁使能</b><br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 12 | LCK12 | <b>GPIOx12 加锁使能</b><br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 11 | LCK11 | <b>GPIOx11 加锁使能</b><br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 10 | LCK10 | <b>GPIOx10 加锁使能</b><br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 9  | LCK9  | <b>GPIOx9 加锁使能</b><br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 8  | LCK8  | <b>GPIOx8 加锁使能</b><br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 7  | LCK7  | <b>GPIOx7 加锁使能</b><br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 6  | LCK6  | <b>GPIOx6 加锁使能</b><br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 5  | LCK5  | <b>GPIOx5 加锁使能</b><br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 4  | LCK4  | <b>GPIOx4 加锁使能</b><br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 3  | LCK3  | <b>GPIOx3 加锁使能</b><br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 2  | LCK2  | <b>GPIOx2 加锁使能</b><br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 1  | LCK1  | <b>GPIOx1 加锁使能</b><br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |
| 0  | LCK0  | <b>GPIOx0 加锁使能</b><br>0x0: 关闭<br>0x1: 打开  | RW | 0x0 |

对 GPIO 进行加锁，需要进行以下操作（以加锁 GPIOA15 为示例）：

- ①GPIOA\_LCK = (1<<16) | (1<<15);
- ②GPIOA\_LCK = (0<<16) | (1<<15);
- ③GPIOA\_LCK = (1<<16) | (1<<15);
- ④读取寄存器 GPIOA\_LCK;
- ⑤读取寄存器 GPIOA\_LCK，确认 BIT16 是否为 1。

#### 7.3.3.10. GPIOx\_AFRL

| Bit(s) | Name | Description                                                                    | R/W | Reset |
|--------|------|--------------------------------------------------------------------------------|-----|-------|
| 31:28  | AFR7 | GPIOx7 的 AF 多功能配置<br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW  | 0x0   |
| 27:24  | AFR6 | GPIOx6 的 AF 多功能配置<br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW  | 0x0   |
| 23:20  | AFR5 | GPIOx5 的 AF 多功能配置<br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW  | 0x0   |
| 19:16  | AFR4 | GPIOx4 的 AF 多功能配置<br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW  | 0x0   |
| 15:12  | AFR3 | GPIOx3 的 AF 多功能配置<br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW  | 0x0   |
| 11:8   | AFR2 | GPIOx2 的 AF 多功能配置<br>0x0: AF0<br>0x1: AF1                                      | RW  | 0x0   |

|     |      |                                                                                       |    |     |
|-----|------|---------------------------------------------------------------------------------------|----|-----|
|     |      | 0x2: AF2<br>0x3: AF3<br>Other: 保留                                                     |    |     |
| 7:4 | AFR1 | <b>GPIOx1 的 AF 多功能配置</b><br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW | 0x0 |
| 3:0 | AFR0 | <b>GPIOx0 的 AF 多功能配置</b><br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW | 0x0 |

#### 7.3.3.11. GPIOx\_AFRH

| Bit(s) | Name  | Description                                                                            | R/W | Reset |
|--------|-------|----------------------------------------------------------------------------------------|-----|-------|
| 31:28  | AFR15 | <b>GPIOx15 的 AF 多功能配置</b><br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW  | 0x0   |
| 27:24  | AFR14 | <b>GPIOx14 的 AF 多功能配置</b><br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW  | 0x0   |
| 23:20  | AFR13 | <b>GPIOx13 的 AF 多功能配置</b><br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW  | 0x0   |
| 19:16  | AFR12 | <b>GPIOx12 的 AF 多功能配置</b><br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW  | 0x0   |
| 15:12  | AFR11 | <b>GPIOx11 的 AF 多功能配置</b>                                                              | RW  | 0x0   |

|      |       |                                                                                        |    |     |
|------|-------|----------------------------------------------------------------------------------------|----|-----|
|      |       | 0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留                              |    |     |
| 11:8 | AFR10 | <b>GPIOx10 的 AF 多功能配置</b><br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留 | RW | 0x0 |
| 7:4  | AFR9  | <b>GPIOx9 的 AF 多功能配置</b><br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留  | RW | 0x0 |
| 3:0  | AFR8  | <b>GPIOx8 的 AF 多功能配置</b><br>0x0: AF0<br>0x1: AF1<br>0x2: AF2<br>0x3: AF3<br>Other: 保留  | RW | 0x0 |

### 7.3.3.12. GPIOx\_TGL

| Bit(s) | Name     | Description                                 | R/W | Reset |
|--------|----------|---------------------------------------------|-----|-------|
| 31:16  | Reserved | -                                           | -   | -     |
| 15     | TG15     | <b>GPIOx15 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO  | 0x0   |
| 14     | TG14     | <b>GPIOx14 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO  | 0x0   |
| 13     | TG13     | <b>GPIOx13 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO  | 0x0   |
| 12     | TG12     | <b>GPIOx12 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO  | 0x0   |
| 11     | TG11     | <b>GPIOx11 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO  | 0x0   |
| 10     | TG10     | <b>GPIOx10 翻转配置</b>                         | WO  | 0x0   |

|   |     |                                            |    |     |
|---|-----|--------------------------------------------|----|-----|
|   |     | 0x0: 无效<br>0x1: 输出翻转                       |    |     |
| 9 | TG9 | <b>GPIOx9 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO | 0x0 |
| 8 | TG8 | <b>GPIOx8 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO | 0x0 |
| 7 | TG7 | <b>GPIOx7 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO | 0x0 |
| 6 | TG6 | <b>GPIOx6 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO | 0x0 |
| 5 | TG5 | <b>GPIOx5 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO | 0x0 |
| 4 | TG4 | <b>GPIOx4 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO | 0x0 |
| 3 | TG3 | <b>GPIOx3 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO | 0x0 |
| 2 | TG2 | <b>GPIOx2 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO | 0x0 |
| 1 | TG1 | <b>GPIOx1 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO | 0x0 |
| 0 | TG0 | <b>GPIOx0 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | WO | 0x0 |

### 7.3.3.13. GPIOx\_IMK

| Bit(s) | Name     | Description                               | R/W | Reset |
|--------|----------|-------------------------------------------|-----|-------|
| 31:16  | Reserved | -                                         | -   | -     |
| 15     | IMK15    | <b>GPIOx15 中断使能</b><br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 14     | IMK14    | <b>GPIOx14 中断使能</b><br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 13     | IMK13    | <b>GPIOx13 中断使能</b>                       | RW  | 0x0   |

|    |       |                                             |    |     |
|----|-------|---------------------------------------------|----|-----|
|    |       | 0x0: 关闭<br>0x1: 打开                          |    |     |
| 12 | IMK12 | <b>GPIOx12 中断使能</b><br>0x0: 关闭<br>0x1: 打开   | RW | 0x0 |
| 11 | IMK11 | <b>GPIOx11 翻转配置</b><br>0x0: 无效<br>0x1: 输出翻转 | RW | 0x0 |
| 10 | IMK10 | <b>GPIOx10 中断使能</b><br>0x0: 关闭<br>0x1: 打开   | RW | 0x0 |
| 9  | IMK9  | <b>GPIOx9 中断使能</b><br>0x0: 关闭<br>0x1: 打开    | RW | 0x0 |
| 8  | IMK8  | <b>GPIOx8 中断使能</b><br>0x0: 关闭<br>0x1: 打开    | RW | 0x0 |
| 7  | IMK7  | <b>GPIOx7 中断使能</b><br>0x0: 关闭<br>0x1: 打开    | RW | 0x0 |
| 6  | IMK6  | <b>GPIOx6 中断使能</b><br>0x0: 关闭<br>0x1: 打开    | RW | 0x0 |
| 5  | IMK5  | <b>GPIOx5 中断使能</b><br>0x0: 关闭<br>0x1: 打开    | RW | 0x0 |
| 4  | IMK4  | <b>GPIOx4 中断使能</b><br>0x0: 关闭<br>0x1: 打开    | RW | 0x0 |
| 3  | IMK3  | <b>GPIOx3 中断使能</b><br>0x0: 关闭<br>0x1: 打开    | RW | 0x0 |
| 2  | IMK2  | <b>GPIOx2 中断使能</b><br>0x0: 关闭<br>0x1: 打开    | RW | 0x0 |
| 1  | IMK1  | <b>GPIOx1 中断使能</b><br>0x0: 关闭<br>0x1: 打开    | RW | 0x0 |
| 0  | IMK0  | <b>GPIOx0 中断使能</b><br>0x0: 关闭<br>0x1: 打开    | RW | 0x0 |

## 8. 通信接口外设 CSI

### 8.1. SPI\_I2C

该模块实现了 SPI/IIC 共用同一个控制器的功能，当使用 SPI 时，IIC 功能不可使用，同一个时刻，只能使用一种协议。

#### 8.1.1. SPI 功能描述

1、支持主机模式和从机模式

2、支持一下四种采样方式：

mode 0：时钟 idle 为 0，上升沿采样，下降沿出数据

mode 1：时钟 idle 为 0，下降沿采样，上升沿出数据

mode 2：时钟 idle 为 1，下降沿采样，上升沿出数据

mode 3：时钟 idle 为 1，上升沿采样，下降沿出数据

3、支持正常模式、3 线模式、双线模式和四线模式。

正常模式：CLK、CS、IO0(MOSI)、IO1(MISO)

3 线模式：CLK、CS、IO0(接收和发送都通过 IO0)

双线模式：CLK、CS、IO0、IO1(接收和发送都通过 IO0、IO1)

四线模式：CLK、CS、IO0、IO1、IO2、IO3(接收和发送都通过 IO0、IO1、IO2、IO3)

4、数据大小支持 1bit 到 32bit，可配置，但是模式不同时有限制。在正常模式和 3 线模式下，数据大小可以是 1 到 32 位可配置；在双线模式下，数据大小必须能被 2 整除；在四线模式下，数据大小必须能被 4 整除。

1、可以选择在一个数据帧中先发送低位数据或高位数据。当高位在前时，IO3 传输最高位，IO2 传输第二高位，IO1 传输第三高位，IO0 传输第四个高位。当低位优先时，IO3 传输最低位，IO2 传输次低位，IO1 传输第三个低位，IO0 传输第四个低位。

6、支持 DMA 功能。

### 8.1.2. I2C 功能描述

- 1、支持主机模式和从机模式
- 2、master 支持时钟同步和仲裁
- 3、slave 支持在发送数据没有准备好或者接收 buffer 满的时候拉低 SCL
- 4、slave 支持 7bit 地址或者 10bit 地址
- 5、支持 DMA

### 8.1.3. SPI 时序图



图 9-1 正常模式下时序图



图 9-2 双线模式下时序图



图 9-3 四线模式下时序图

#### 8.1.4. IO MAPPING

SPI\_I2C0:

SPI0\_NSS: PA0(AF2)

SPI0\_SCK/I2C0\_SCL/MOSI: PA1(AF2)、PA10(AF1)、PB3(AF3)

SPI0\_IO0/I2C0\_SDA/MISO : PA2(AF2)、PA11(AF1)、PE2(AF0)

SPI0\_IO1: PA3(AF2)、PA12(AF1)、PB4(AF3)

SPI0\_IO2: PA4(AF2)

SPI0\_IO3: PA5(AF2)

SPI\_I2C1:

SPI1\_NSS: PB5(AF1)、PA6(AF2)

SPI1\_SCK/I2C1\_SCL/MOSI: PB6(AF1)、PA7(AF2)

SPI1\_IO0/I2C1\_SDA/MISO: PB7(AF1)、PA8(AF2)

SPI1\_IO1: PB8(AF1)、PA9(AF2)

SPI1\_IO2: PB9(AF1)、PA10(AF2)

SPI1\_IO3: PB10(AF1)、PA11(AF2)

## 8.2. 寄存器

### 8.2.1. 寄存器基地址

| Name     | Base Address | Description   |
|----------|--------------|---------------|
| SPI_I2C0 | 0x40004400   | SPI0/I2C0 基地址 |
| SPI_I2C1 | 0x40004500   | SPI1/I2C1 基地址 |

### 8.2.2. 寄存器列表

| Offset Address | Name                | Description     |
|----------------|---------------------|-----------------|
| 0x0000         | SPIx_CON0/I2Cx_CON0 | SPI/I2C 控制寄存器 0 |
| 0x0004         | SPIx_CON1/I2Cx_CON1 | SPI/I2C 控制寄存器 1 |
| 0x0008         | SPIx_DATA/I2Cx_DATA | SPI/I2C 数据寄存器   |

|        |                             |                   |
|--------|-----------------------------|-------------------|
| 0x000c | SPIx_BAUD/I2Cx_BAUD         | SPI/I2C 波特率寄存器    |
| 0x0010 | SPIx_DAMLEN/I2Cx_DAMLEN     | SPI/I2C DMA 长度寄存器 |
| 0x0014 | SPIx_DMACNT/I2Cx_DMACNT     | SPI/I2C DMA 计数寄存器 |
| 0x0018 | SPIx_DMASTART/I2Cx_DMASTART | SPI/I2C DMA 触发寄存器 |
| 0x001c | SPIx_STA/I2Cx_STA           | SPI/I2C 状态寄存器     |

### 8.2.3. 寄存器详细说明

#### 8.2.3.1. SPIx\_CON0

| Bit(s) | Name           | Description                                                                                                    | R/W | Reset |
|--------|----------------|----------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:20  | Reserved       | -                                                                                                              | -   | -     |
| 19:14  | SPI_FRAME_SIZE | <b>SPI 帧大小配置</b><br>0x00: 无效<br>0x01: 每一帧发送 1bit<br>0x02: 每一帧发送 2bit<br>...<br>0x20: 每一帧发送 32bit<br>Other: 无效  | RW  | 0x0   |
| 13     | NSS_POS_IE     | <b>SPI 从机模式, SPI_NSS 引脚中断使能</b><br>0x0: 关闭<br>0x1: 打开                                                          | RW  | 0x0   |
| 12     | SPI_NSS_EN     | <b>SPI 从机模式, SPI_NSS 引脚使能</b><br>0x0: 关闭<br>0x1: 打开                                                            | RW  | 0x0   |
| 11     | SPI_NSS        | <b>SPI NSS 引脚控制输出</b><br>此位仅在 SPI 主模式下有效<br>0x0: 输出低电平<br>0x1: 输出高电平                                           | RW  | 0x0   |
| 10:8   | RXSEL          | <b>SPI 主机采样延迟的配置</b><br>0x0: no delay<br>0x1: delay 1 cycle<br>0x2: delay 2 cycle<br>...<br>0x7: delay 7 cycle | RW  | 0x0   |
| 7      | SLAVE_SYNC_EN  | <b>SPI SLAVE 模式下, 输入数据是否需要同步的选择位</b><br>0x0: 关闭<br>0x1: 打开                                                     | RW  | 0x0   |
| 6      | MASTER_SYNC_EN | <b>SPI MASTER 模式下, 输入数据是否需要同步的选择位</b>                                                                          | RW  | 0x0   |

|     |          |                                                                                                                                                      |    |     |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |          | 0x0: 关闭<br>0x1: 打开                                                                                                                                   |    |     |
| 5   | Reserved | -                                                                                                                                                    | -  | -   |
| 4   | LSBFE    | SPI 传输从低位使能<br>0x0: 高位优先<br>0x1: 低位优先                                                                                                                | RW | 0x0 |
| 3:2 | WIREMODE | SPI 通信线模式选择<br>0x0: 正常模式<br>0x1: 3 线模式<br>0x2: 双线模式<br>0x3: 四线模式                                                                                     | RW | 0x0 |
| 1:0 | SPI MODE | SPI 模式选择<br>0x0: 时钟 idle 为 0, 上升沿采样, 下降沿出数据<br>0x1: 时钟 idle 为 0, 下降沿采样, 上升沿出数据<br>0x2: 时钟 idle 为 1, 下降沿采样, 上升沿出数据<br>0x3: 时钟 idle 为 1, 上升沿采样, 下降沿出数据 | RW | 0x0 |

#### 8.2.3.2. IICx\_CON0

| Bit(s) | Name           | Description                                                                                         | R/W | Reset |
|--------|----------------|-----------------------------------------------------------------------------------------------------|-----|-------|
| 31:23  | Reserved       | -                                                                                                   | -   | -     |
| 22     | RX_NACK_IE     | 接收到 NACK 中断使能<br>0x0: 关闭<br>0x1: 打开                                                                 | RW  | 0x0   |
| 21     | I2C_AL_IE      | 主机仲裁丢失中断使能<br>0x0: 关闭<br>0x1: 打开                                                                    | RW  | 0x0   |
| 20     | STOP_IE        | 检测到线上有 STOP 信号中断使能, 不管是从机主机都会起来<br>0x0: 关闭<br>0x1: 打开                                               | RW  | 0x0   |
| 19     | ADR_MATCH_IE   | SLAVE 地址匹配中断使能<br>0x0: 关闭<br>0x1: 打开                                                                | RW  | 0x0   |
| 18:14  | I2C_FILTER_CNT | I2C 每 (I2C_FILTER_CNT +1) 个 I2C 模块时钟, 采样一次 SCL 和 SDA, 用于滤除一定宽度的线路毛刺。I2C_FILTER_CNT 配置越大, 虤掉的毛刺宽度越大。 | RW  | 0x0   |
| 13     | BROADCAST_IE   | 广播中断使能<br>0x0: 关闭<br>0x1: 打开                                                                        | RW  | 0x0   |
| 12     | BROADCAST_EN   | I2C 作为 slave 时候, 是否使能接收广播地址<br>0x0: 忽略广播地址<br>0x1: 接收到广播地址时, 回应 ACK, 并且将 BROADCAST_PEND 置起来, 可以产生中断 | RW  | 0x0   |

|      |                 |                                                           |    |     |
|------|-----------------|-----------------------------------------------------------|----|-----|
| 11:2 | SLAVE_ADR       | I2C 作为 SLAVE 时候, SLAVE 地址                                 | RW | 0x0 |
| 1    | TX_NACK         | I2C 在接收数据的时候, 回应 NACK 还是 ACK 选择位<br>0x0: ACK<br>0x1: NACK | RW | 0x0 |
| 0    | SLAVE_ADR_WIDTH | I2C 作为 SLAVE 时候, SLAVE 地址宽度<br>0x0: 7bit<br>0x1: 10bit    | RW | 0x0 |

### 8.2.3.3. SPIx\_CON1 / IICx\_CON1

| Bit(s) | Name           | Description                                                                                                                                          | R/W | Reset |
|--------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:10  | Reserved       |                                                                                                                                                      | -   | -     |
| 9      | DMA_IE         | <b>DMA 完成中断使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                              | RW  | 0x0   |
| 8      | BUF_OV_IE      | <b>buffer 溢出, 有数据丢失了中断使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                   | RW  | 0x0   |
| 7      | RBUF_NEMPTY_IE | <b>接收 buffer 不空中断使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                        | RW  | 0x0   |
| 6      | TBUF_NFULL_IE  | <b>发送 buffer 不满中断使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                        | RW  | 0x0   |
| 5      | SSP_IE         | <b>I2C 接口:</b><br>I2C master 接收或者发送完成一帧数据 (START + WRITE/READ(8bit+ack) + STOP) 中断使能<br>I2C slave 接收或者发送完成一帧数据(8bit+ack) 中断使能;<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 4      | DMA_EN         | <b>发送 DMA 使能</b><br>0x0: 关闭<br>0x1: 打开<br>注: 如果 SSP_TX_EX_EN==0, 表示 DMA 发送; 如果 SSP_TX_EX_EN==1, 表示 DMA 接收;                                           | RW  | 0x0   |
| 3      | SSP_TX_RX_EN   | <b>接口发送使能</b><br>0x0: RX_EN<br>0x1: TX_EN                                                                                                            | RW  | 0x0   |
| 2      | SLAVE          | <b>SLAVE 模式使能</b><br>0x0: master mode<br>0x1: slave mode                                                                                             | RW  | 0x0   |
| 1      | SPI_I2C_SEL    | <b>SPI 和 I2C 选择位</b>                                                                                                                                 | RW  | 0x0   |

|   |        |                                   |    |     |
|---|--------|-----------------------------------|----|-----|
|   |        | 0x0: SPI 接口<br>0x1: I2C 接口        |    |     |
| 0 | SSP_EN | <b>模块使能</b><br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

#### 8.2.3.4. SPIx\_DATA / IICx\_DATA

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R/W | Reset |
|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:0   | SSP_CMD_DATA | <p><b>SPI 接口:</b><br/>           Write: 将想要发送的数据写入这个寄存器，触发 SPI 发送；<br/>           Read: 读这个寄存器，获取收到的数据。</p> <p><b>I2C 接口:</b><br/>           Write:<br/>           [7:0] 将想要发送的数据写入这 8bit;<br/>           [8] START 使能位，在将这 byte 数据发出去前，先插入一个 start bit (只在 I2C_MASTER 模式有效)；<br/>           [9] STOP 使能位，在将这 byte 数据发出去后，紧跟一个 stop bit (只在 I2C_MASTER 模式有效)。<br/>           Read:<br/>           读这个寄存器，获取收到的数据 (bit7~bit0)<br/>           [31:10] 没有使用         </p> | RW  | 0x0   |

#### 8.2.3.5. SPIx\_BAUD / IICx\_BAUD

| Bit(s) | Name     | Description                                                                                                                                                                                                                        | R/W | Reset |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | Reserved | -                                                                                                                                                                                                                                  | -   | -     |
| 15:0   | BAUD     | <p><b>MASTER 模式</b></p> <p>①SPI 波特率=apb0_clock/(2*(BAUD+1))<br/>           ②I2C 波特率= apb0_clock/(4*(BAUD+1))</p> <p><b>SLAVE 模式</b></p> <p>①SPI 没有用<br/>           ②I2C 用于定义从机准备好发送数据，再 delay(BAUD+1) 个 apb0_clock 周期后才释放 SCL。</p> | RW  | 0x0   |

### 8.2.3.6. SPIx\_DMALEN / IICx\_DMALEN

| Bit(s) | Name        | Description                    | R/W | Reset |
|--------|-------------|--------------------------------|-----|-------|
| 31:12  | Reserved    | -                              | -   | -     |
| 11:0   | SPI_DMA_LEN | 配置接收和发送 DMA 数据的长度<br>接收单位 byte | RW  | 0x0   |

### 8.2.3.7. SPIx\_DMACNT / IICx\_DMACNT

| Bit(s) | Name        | Description                                                                                                                                                                  | R/W | Reset |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:12  | Reserved    | -                                                                                                                                                                            | -   | -     |
| 11:0   | SPI_DMA_CNT | 接收和发送 DMA 模式: 实际接收并且保存到 SRAM 的数据 byte 长度<br>在 master 模式, RX_DMA_EN 为 0 时候, 接收数据: 表示实际接收并且已经被 CPU 读走的数据 byte 长度;<br>注: 在 RX_DMA_EN 上升沿, TX_DMA_EN 上升沿, 以及 MSTER 读上升沿的时候, 被清零。 | RO  | 0x0   |

### 8.2.3.8. SPIx\_DMASTADR / IICx\_DMASTADR

| Bit(s) | Name          | Description                                     | R/W | Reset |
|--------|---------------|-------------------------------------------------|-----|-------|
| 31:13  | Reserved      | -                                               | -   | -     |
| 12:0   | SPI_DMA_STADR | DMA 地址, 一帧数据是 32bit 时候, 需要 32bit 对齐, 其他时候可以任意配置 | RW  | 0x0   |

### 8.2.3.9. SPIx\_STA / IICx\_STA

| Bit(s) | Name       | Description                                                                                                                                                                                                                                 | R/W | Reset |
|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:28  | Reserved   | -                                                                                                                                                                                                                                           | -   | -     |
| 27     | SLV_ADDRED | 从机模式, 从机被寻址标志位<br>0x0: 从机没有被寻址<br>0x1: 从机已经被寻址                                                                                                                                                                                              | RO  | 0x0   |
| 26:24  | STATE      | I2C 状态<br>0x0: IDLE 空闲空闲<br>0x1: START 发送 start 已经接收到 start, 等待 SCL 变 0<br>0x2: TX 发送 1byte 数据发送 1byte 数据<br>0x3: RX 接收 1byte 数据接收 1byte 数据<br>0x4: STOP 发送 stop no use<br>0x5: ADRO no use 等待接收 1byte 地址<br>0x6: ADR1 no use 等待接收 2byte 地址 | RO  | 0x0   |

|       |                |                                                                                                                                                                                                    |    |      |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------|
|       |                | 0x7: no use                                                                                                                                                                                        |    |      |
| 23:20 | Reserved       | -                                                                                                                                                                                                  | -  | -    |
| 19    | CLR_BUF_CNT    | Write 1 清零 BUF_CNT<br>Write 0 没有任何作用<br>Read: 总是返回 0                                                                                                                                               | WO | 0x0  |
| 18:16 | BUF_CNT        | buffer 里面有多少 byte 有效数据, CPU 每读 (RX_EN) / 写 (TX_EN) 一次 CMD_DATA 寄存器, 减 / 加一个帧数据宽度, 8bit 数据减 1, 16bit 数据减 2, 24bit 和 32bit 数据减 4                                                                     | RO | 0x0  |
| 15    | MASTER_RX_BUSY | 在 MASTER 读从机模式, 指示软件配置的连续读取 DMA_LEN byte 数据是否完成<br>0x0: 已经读完<br>0x1: 还没有读完                                                                                                                         | RO | 0x0  |
| 14    | I2C_RX_NACK    | I2C 主机或者从机, 在发送数据的时候, 在第 9bit 握手阶段, 检测到 ACK 还是 NACK<br>0x0: ACK<br>0x1: NACK                                                                                                                       | RO | 0x0  |
| 13    | I2C_SLAVE_RW   | IIC 从机, 在地址阶段, 接收到的主机发过来的读写标志<br>0x1: 主机将读从机<br>0x0: 主机将写从机                                                                                                                                        | RO | 0x0  |
| 12    | I2C_BUS_BUSY   | IIC 线路是否 busy 指示位<br>0x0: 线路上一直没有出现 START, 或者出现 START 后又出现了 STOP, 线路空闲<br>0x1: 检测到线路上出现了 START, 并且一直没有出现 STOP, 线路忙<br>注: 只能硬件清                                                                     | RO | 0x0  |
| 11    | SPI_SLAVE_CS   | SPI SLAVE, CS 的状态                                                                                                                                                                                  | RO | 0x01 |
| 10    | SSP_BUSY       | SPI 或者 IIC 正忙<br>0x0: MASTER 空闲<br>SLAVE 没有在发送数据, 接收的时候不使用<br>0x1: MASTER 正在接收或者发送一帧数据<br>SLAVE 正在发送一帧数据, 接收的时候不使用<br>注: 硬件清, 或者关掉 SPI 和 IIC(CON1[0]==0), 或者在 slave 时候, CLR_BUF_CNT 会同时清掉 SSP_BUSY | RO | 0x0  |
| 9     | AL_PEND        | IIC 主机, 检测到仲裁丢失<br>0x0: 没有仲裁丢失<br>0x1: 仲裁丢失<br>注: 只能软件清, 必须清掉 IIC 才能正常工作                                                                                                                           | RC | 0x0  |
| 8     | STOP_PEND      | IIC 接口, 检测到线路上产生了 STOP 位<br>0x0: 没有检测到 STOP 位。<br>0x1: 检测到 STOP 位。<br>注: 只能软件清                                                                                                                     | RC | 0x0  |
| 7     | ADR_MTCH_PEND  | IIC 从机, 接收到主机发送过来的对的从机地址<br>0x1: 从机地址匹配                                                                                                                                                            | RC | 0x0  |

|     |                    |                                                                                                                                                                                                                               |    |      |
|-----|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------|
|     |                    | 0x0: 从机地址不匹配<br>注: 只能软件清                                                                                                                                                                                                      |    |      |
| 6   | I2C_BROADCAST_PEND | IIC 作为 SLAVE 时候, 检测到广播地址标志位<br>0x0: 没有检测到广播地址<br>0x1: 检测到广播地址<br>注: 只能软件清                                                                                                                                                     | RC | 0x0  |
| 5   | SPI_NSS_POS        | 检测到 SPI NSS 引脚上升沿<br>0x0: 没有检测到上升沿<br>0x1: 检测到上升沿<br>注: 只能软件清                                                                                                                                                                 | RC | 0x0  |
| 4   | DMA_PEND           | 发送 DMA 或者接收 DMA 完成标志<br>0x0: DMA 没有完成<br>0x1: DMA 已经完成<br>注: 只能软件清                                                                                                                                                            | RC | 0x0  |
| 3   | BUF_OV             | buffer 溢出, 有数据丢失了<br>0x0: buffer 没有溢出<br>0x1: 在 buffer 已经是满状态 (buffer 容量是 5byte, 满并不一定是 5byte, 而是空间容不下一帧数据了), 又有数据接收到。丢弃后来的数据.<br>注: 只能软件清                                                                                    | RC | 0x0  |
| 2   | BUF_EMPTY          | buffer 空标志                                                                                                                                                                                                                    | RO | 0x01 |
| 1   | BUF_FULL           | buffer 满标志位<br>0x0: 不满<br>0x1: 满                                                                                                                                                                                              | RO | 0x0  |
| 0x0 | SSP_DONE           | 完成标志<br>0x0: 没有完成<br>0x1: SPI 接口<br>SPI 已经完成一帧 (8bit/16bit/24bit/32bit)<br>数据的接收或者发送<br>I2C 接口 I2C MASTER 已经完成了一帧数据的接收或者发送 (START (可选) + WRITE/READ (8bit+ack) + STOP (可选)) I2C SLAVE 已经完成了一帧数据的接收或者发送 (8bit+ack)<br>注: 只能软件清 | RC | 0x0  |

## 8.2.4. 使用说明

### 8.2.4.1. SPI 模块使用

SPI MASTER 初始化:

1. IO mapping 配置, 将数据通路打通
2. 配置 BAUD
3. 配置 CON0
4. 配置配置 CON1
5. SPI MASTER 使能: SPIx->CON1 |= 0x01;

SPI MASTER 非 DMA 发送:

1. SSP\_TX\_EN 使能: SPIx->CON1 |= (1<<3); //tx enable
2. 若 初始化 时 SPI\_NSS\_EN, 需 要 将 NSS 拉 低 : SPIx->CON0 &= ~(1<<11); //nssnegedge
2. 判断发送 buffer 是否 full, 没有 full 就可以往 CMD\_DATA 填数据
3. 将所有想发的数据都填入 CMD\_DATA 后, 等待发送 buffer 空, 以及 ssp\_busy 为 0。
4. 若初始化时 SPI\_NSS\_EN, 需要将 NSS 拉高: SPIx->CON0 |= (1<<11); //nssposedge
5. 结束。

SPI MASTER DMA 发送:

1. SSP\_TX\_EN 使能: SPIx->CON1 |= (1<<3); //tx enable
2. 若 初始化 时 SPI\_NSS\_EN, 需 要 将 NSS 拉 低 : SPIx->CON0 &= ~(1<<11); //nssnegedge
2. 配置 DMA\_STADR, DMA\_LEN
3. 使能 DMA: SPIx->CON1 |= (1<<4); // DMA EN\
4. 等待 DMA 结束: while((SPIx->STA & (1<<4))==0); //WAIT DMA PEND
5. 若初始化时 SPI\_NSS\_EN, 需要将 NSS 拉高: SPIx->CON0 |= (1<<11); //nssposedge
6. 结束。

SPI MASTER 非 DMA 接收:

1. SSP\_RX\_EN 使能: SPIx->CON1 &= ~(1<<3); //rx enable
2. 若 初始化 时 SPI\_NSS\_EN, 需 要 将 NSS 拉 低 : SPIx->CON0 &= ~(1<<11); //nssnegedge
2. 配置 DMA\_LEN 为想接收的数据的 byte 数
3. 写 CMD\_DATA 触发接收开始。
4. 查询接收 buffer 为非空。通过读 DMA\_DATA 取走数据。
5. 重复 4, 直到读走 DMA\_LEN 的数据

6. 若初始化时 SPI\_NSS\_EN, 需要将 NSS 拉高: SPIx->CON0 |= (1<<11); //nssposedge

7. 结束。

SPI MASTER DMA 接收:

1. SSP\_RX\_EN 使能: SPIx->CON1 &= ~(1<<3); //rx enable

2. 若 初始化 时 SPI\_NSS\_EN, 需 要 将 NSS 拉 低 : SPIx->CON0 &= ~(1<<11); //nssnegedge

2. 配置 DMA\_LEN 为想接收的数据的 byte 数

3. 使能 DMA: SPIx->CON1 |= (1<<4); //

4. 等待 DMA 结束: while((SPIx->STA & (1<<4))==0); //WAIT DMA PEND

5. 若初始化时 SPI\_NSS\_EN, 需要将 NSS 拉高: SPIx->CON0 |= (1<<11); //nssposedge

6. 结束。

SPI SLAVE 初始 化:

1. IO mapping 配置, 将数据通路打通

2. 配置 CON0

3. 配置 CON1

4. SPI SLAVE 使能: SPIx->CON1 |= 0x05;

SPI SLAVE 非 DMA 发送:

1. SSP\_TX\_EN 使能: SPIx->CON1 |= (1<<3); //tx enable

2. 判断发送 buffer 是否 full, 没有 full 就可以往 CMD\_DATA 填数据

3. 将所有想发的数据都填入 CMD\_DATA 后, 等待发送 buffer 空, 以及 ssp\_busy 为 0。

4. 结束。

SPI SLAVE DMA 发送:

1. SSP\_TX\_EN 使能: SPIx->CON1 |= (1<<3); //tx enable

2. 配置 DMA\_STADR, DMA\_LEN

3. 使能 DMA: SPIx->CON1 |= (1<<4); // DMA EN\

4. 等待 DMA 结束: while((SPIx->STA & (1<<4))==0); //WAIT DMA PEND

5. 结束。

SPI SLAVE 非 DMA 接收:

1. SSP\_RX\_EN 使能: SPIx->CON1 &= ~(1<<3); //rx enable

2. 查询接收 buffer 为非空。通过读 DMA\_DATA 取走数据。
3. 重复 2，直到读走所有需要的数据
4. 结束。

SPI SLAVE DMA 接收：

1. SSP\_RX\_EN 使能： SPIx->CON1 &= ~(1<<3); //rx enable
2. 配置 DMA\_LEN 为想接收的数据的 byte 数
3. 使能 DMA:SPIx->CON1 |= (1<<4);
4. 等待 DMA 结束： while((SPIx->STA & (1<<4))==0); //WAIT DMA PEND
5. 结束。

#### 8.2.4.2. I2C 模块使用说明

I2C MASTER 初始化：

1. IO mapping 配置，将数据通路打通
2. 配置 BAUD
3. 配置 CON0
4. 配置配置 CON1
5. SPI MASTER 使能： SPIx->CON1 |= 0x03;

I2C MASTER 非 DMA 发送：

1. SSP\_TX\_EN 使能： SPIx->CON1 |= (1<<3); //tx enable
2. 判断发送 buffer 是否 full，没有 full 就可以往 CMD\_DATA 填数据
3. 将所有想发的数据都填入 CMD\_DATA 后，等待发送 buffer 空，以及 ssp\_busy 为 0。
4. 结束。

I2C MASTER DMA 发送：

1. SSP\_TX\_EN 使能： SPIx->CON1 |= (1<<3); //tx enable
2. 配置 DMA\_STADR, DMA\_LEN
3. 使能 DMA:SPIx->CON1 |= (1<<4);
4. 等待 DMA 结束： while((SPIx->STA & (1<<4))==0); //WAIT DMA PEND
5. 结束。

I2C MASTER 非 DMA 接收：

1. SSP\_RX\_EN 使能: SPIx->CON1 &= ~(1<<3); //rx enable
2. 配置 DMA\_LEN 为想接收的数据的 byte 数
3. 写 CMD\_DATA 触发接收开始。
4. 查询接收 buffer 为非空。通过读 DMA\_DATA 取走数据。
5. 重复 4, 直到读走 DMA\_LEN 的数据
6. 结束。

I2C MASTER DMA 接收:

1. SSP\_RX\_EN 使能: SPIx->CON1 &= ~(1<<3); //rx enable
2. 配置 DMA\_LEN 为想接收的数据的 byte 数
3. 使能 DMA:SPIx->CON1 |= (1<<4);
4. 等待 DMA 结束: while((SPIx->STA & (1<<4))==0); //WAIT DMA PEND
5. 结束。

I2C SLAVE 初始化:

1. IO mapping 配置, 将数据通路打通
2. 配置 CON0
3. 配置 CON1
4. SPI SLAVE 使能: SPIx->CON1 |= 0x07;

I2C SLAVE 非 DMA 发送:

1. SSP\_TX\_EN 使能: SPIx->CON1 |= (1<<3); //tx enable
2. 判断发送 buffer 是否 full, 没有 full 就可以往 CMD\_DATA 填数据
3. 将所有想发的数据都填入 CMD\_DATA 后, 等待发送 buffer 空, 以及 ssp\_busy 为 0。
4. 结束。

I2C SLAVE DMA 发送:

1. SSP\_TX\_EN 使能: SPIx->CON1 |= (1<<3); //tx enable
2. 配置 DMA\_STADR, DMA\_LEN
3. 使能 DMA:SPIx->CON1 |= (1<<4); // DMA EN\
4. 等待 DMA 结束: while((SPIx->STA & (1<<4))==0); //WAIT DMA PEND
5. 结束。

I2C SLAVE 非 DMA 接收:

1. SSP\_RX\_EN 使能: SPIx->CON1 &= ~(1<<3); //rx enable
2. 查询接收 buffer 为非空。通过读 DMA\_DATA 取走数据。
3. 重复 2, 直到读走所有需要的数据
4. 结束。

I2C SLAVE DMA 接收:

1. SSP\_RX\_EN 使能: SPIx->CON1 &= ~(1<<3); //rx enable
2. 配置 DMA\_LEN 为想接收的数据的 byte 数
3. 使能 DMA:SPIx->CON1 |= (1<<4); // DMA EN\
4. 等待 DMA 结束: while((SPIx->STA & (1<<4))==0); //WAIT DMA PEND
5. 结束。

## 9. UART

### 9.1. 概述

**UART0:**

- 支持 8bit 数据和 9bit 数据模式
- 支持奇偶校验，奇校验/偶校验可选
- 支持检测系统更新数据串 (0x70->0x61->0x73->0x53->0xf5->0x1e->0xf4->0xec)
- 具有 4 帧数据的接收缓存，一帧数据的发送缓存
- 硬件检测接收 time out, time out 长度可以配置，配置范围: 1~65536 比特率时间。
- GPIO 映射:

UART0 RX: PB8(fun2)、PE1(fun3)、PA7(fun3)

UART0 TX: PB7(fun2)、PE0(fun3)、PA6(fun3)

**UART1:**

- 支持 8bit 数据和 9bit 数据模式
- 支持奇偶校验，奇校验/偶校验可选

- 具有 4 帧数据的接收缓存，一帧数据的发送缓存
- 支持接收和发送 DMA
- 支持 RS485 模式
- 硬件检测接收 time out，time out 长度可以配置，配置范围：1~65536 比特率时间。
- GPIO 映射：
  - UART1 RX: PB3(fun2)、PE1(fun2)、PA12(fun3)
  - UART1 TX: PB4(fun2)、PE0(fun2)、PA11(fun3)、PE2(fun1)
  - UART1 DE: PB5(fun2)、PB10(fun2)
  - UART1 RE: PB6(fun2)、PE2(fun2)

## 9.2. 寄存器

### 9.2.1. 寄存器地址

| Name  | Base Address | Description |
|-------|--------------|-------------|
| UART0 | 0x40004000   | UART0 基地址   |
| UART1 | 0x40004100   | UART1 基地址   |

### 9.2.2. 寄存器列表

| Offset Address | Name       | Description  |
|----------------|------------|--------------|
| 0x0000         | UART0_CON  | UART0 控制寄存器  |
| 0x0004         | UART0_BUAD | UART0 波特率寄存器 |
| 0x0008         | UART0_DATA | UART0 数据寄存器  |
| 0x000c         | UART0_STA  | UART0 状态寄存器  |

| Offset Address | Name       | Description  |
|----------------|------------|--------------|
| 0x0000         | UART1_CON  | UART1 控制寄存器  |
| 0x0004         | UART1_BUAD | UART1 波特率寄存器 |

|        |                |                     |
|--------|----------------|---------------------|
| 0x0008 | UART1_DATA     | UART1 数据寄存器         |
| 0x000c | UART1_STA      | UART1 状态寄存器         |
| 0x0010 | UART1_TSTADR   | UART1 发送 DMA 起始地址   |
| 0x0014 | UART1_RSTADR   | UART1 接收 DMA 起始地址   |
| 0x0018 | UART1_TDMALEN  | UART1 发送 DMA 的长度    |
| 0x001c | UART1_RDMALEN  | UART1 接收 DMA 的长度    |
| 0x0020 | UART1_TDMACNT  | UART1 已发送 DMA 长度    |
| 0x0024 | UART1_RDMACNT  | UART1 已接收 DMA 长度    |
| 0x0028 | UART1_DMACON   | UART1 DMA 控制寄存器     |
| 0x002c | UART1_DMASTA   | UART1 DMA 状态寄存器     |
| 0x0030 | UART1_RS485CON | UART1 RS485 控制寄存器   |
| 0x0034 | UART1_RS485DET | UART1 RS485 DET 寄存器 |
| 0x0038 | UART1_RS485TAT | UART1 RS485 TAT 寄存器 |

### 9.2.3. 寄存器详细说明

#### 9.2.3.1. UARTx\_CON

| Bit(s) | Name       | Description                                                                                               | R/W | Reset |
|--------|------------|-----------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | TO_BIT_LEN | 配置超时时间<br>单位为比特率时间<br>Time_out_time= (TO_BIT_LEN+1) * bit_rate_time                                       | RW  | 54    |
| 15     | TCIE       | 传输完全中断使能<br>0x0: 关闭<br>0x1: 打开, 当 UART_STA 寄存器中的 TC=1 时产生 UART 中断                                         | RW  | 0x0   |
| 14     | TMR_PWM_EN | UART 的输出和 TIMER 的 PWM 一起运算后才输出<br>使能位 (UART0 输出 timer0 的 PWM、UART1 输出 timer1 的 PWM)<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 13     | TO_IE      | Time out 中断使能<br>0x0: 关闭<br>0x1: 打开                                                                       | RW  | 0x0   |
| 12     | TO_EN      | Time out 检测使能位<br>检测是否在经历了 5 * (1 start_bit + 8 data)                                                     | RW  | 0x0   |

|     |                 |                                                                                                                                                                                          |    |     |
|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |                 | bit + 2 stop bit) 时间, 没有接收到数据。每次 TO_EN 后, 需要等到接收到一 byte 数据才会开始检测。接收到 1byte 数据这个标志, 会在每次清 TO_PEND 的时候被清掉, 或者在 TO_EN 等于 0 的时候被清掉。<br>0x0: 关闭<br>0x1: 打开                                    |    |     |
| 11  | FERR_IE         | <b>帧出错中断使能位</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                                    | RW | 0x0 |
| 10  | TXBUF_EMPTY_IE  | <b>发送 buffer 空中断使能位</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                            | RW | 0x0 |
| 9   | RXBUF_NEMPTY_IE | <b>接收 buffer 空中断使能位</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                            | RW | 0x0 |
| 8   | TX_INV          | <b>发送输出信号取反选择位</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                                 | RW | 0x0 |
| 7   | RX_INV          | <b>接收输入信号取反选择位</b><br>0x0: 不取反<br>0x1: 取反                                                                                                                                                | RW | 0x0 |
| 6   | ODD_EN          | <b>奇偶校验选择</b><br>0x0: 偶校验<br>0x1: 奇校验                                                                                                                                                    | RW | 0x0 |
| 5   | PARITY_EN       | <b>奇偶校验使能</b><br>0x0: 关闭<br>0x1: 打开<br>注: 奇偶检验和 BIT9_EN 只能二选一                                                                                                                            | RW | 0x0 |
| 4   | BIT9_EN         | <b>UART 传输 9bit 数据选择位</b><br>0x0: UART 传输 8bit 数据<br>0x1: UART 传输 9bit 数据<br>注: 奇偶检验和 BIT9_EN 只能二选一                                                                                      | RW | 0x0 |
| 3   | STOP_BIT        | <b>结束位使能位</b><br>0x0: 一个结束位<br>0x1: 两个结束位                                                                                                                                                | RW | 0x0 |
| 2:1 | WORK_MODE       | <b>工作模式</b><br>0x0: 全双工, 可以同时收发<br>0x1: 单工发送<br>0x2: 单工接收<br>0x3: 一根数据线, 硬件自动切换该 IO 方向; 在不是 rs485M 模式, 软件触发发送 IO 方向就是输出, 没有数据发送 IO 方向是输入。在 RS485 模式, DE 为有效时候 IO 是输出, 在 DE 为无效的时候 IO 是输入 | RW | 0x0 |
| 0   | UART_EN         | <b>UART 模块使能位</b>                                                                                                                                                                        | RW | 0x0 |

|  |  |                    |  |  |
|--|--|--------------------|--|--|
|  |  | 0x0: 关闭<br>0x1: 打开 |  |  |
|--|--|--------------------|--|--|

### 9.2.3.2. UARTx\_BAUD

| Bit(s) | Name       | Description                                                                                       | R/W | Reset |
|--------|------------|---------------------------------------------------------------------------------------------------|-----|-------|
| 31:18  | Reserved   | -                                                                                                 | -   | -     |
| 17:0   | UARTx_BAUD | <b>UART 波特率设置</b><br>波特率=SYS_CLK / (UARTx_BAUD+1)<br>注: UARTx_BAUD 一定要配置为大于等于 6, 否则输入信号会被内部滤波器滤掉。 | RW  | 0xa93 |

### 9.2.3.3. UARTx\_DATA

| Bit(s) | Name       | Description                                                                                                                   | R/W | Reset |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:9   | Reserved   | -                                                                                                                             | -   | -     |
| 8:0    | UARTx_DATA | <b>UART 传输数据</b><br>写 8/9 位数据到 UARTx_DATA: 触发 UART 模块开始发送数据。<br>读 UARTx_DATA: 获取接收到的低 8/9bit 数据,<br>读之前, 先读取 PERR[0] 获取奇偶校验信息 | RW  | 0x0   |

### 9.2.3.4. UARTx\_STA

| Bit(s) | Name             | Description                                                                                                                                                               | R/W | Reset |
|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | -                | -                                                                                                                                                                         | -   | -     |
| 15     | TC               | <b>传输完成</b><br>如果一个帧的传输完成并且 TX_BUF_EMPTY 被设置, 那么这个位由硬件设置。如果 UARTx_CON 寄存器中的 TCIE=1, 则产生中断。<br>它由一个软件序列(写入 usart_dr 寄存器)清除。TC 位也可以通过写入“1”来清除。<br>0x0: 表示传输未完成<br>0x1: 传输完成 | RO  | 0x0   |
| 14     | UPDATE_DETECT_EN | <b>系统升级检测使能位</b><br>检测是否接收到了下面的一串连续数据<br>0x70->0x61->0x73->0x53->0xf5->0x1e->0xf4->0xec<br>0x0: 关闭<br>0x1: 打开<br>注: 当 UPDATE_DETECT_EN 为 1, 并且 UPDATE_DETECT_PEND 为 0 时候  | RO  | 0x0   |

|      |                      |                                                                                                                                                                                                              |      |     |
|------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|
|      |                      | UARTx_CON: 将固定为 0x1005(单工接收, 1stop, 8bit 模式, 没有奇偶校验, 没有取反, 所有中断不使能) ; UARTx_BAUD : 将由 EFLASH 模块配置, 默认值会是 0xa93;<br>UART_DMACON: 将固定为 0x00 (不使能 DMA) ;<br>UART_RS485_CON: 将固定为 0x00 (不使能 rs485) ;<br>软件不可以改变。 |      |     |
| 13   | UPDATE_DETECT_PEND_G | 这一位和 UPDATE_DETECT_PEND一样, 只是这位一旦为 1, 除非 reset UART0, 否则一直不会变为 0。                                                                                                                                            | RO   | 0x0 |
| 12   | UPDATE_DETECT_PEND   | <b>检测到系统升级标志位</b><br>表示接收到下面的一串数据<br>0x70->0x61->0x73->0x53->0xf5->0x1e->0xf4->0xec。写 1 清零。<br>0x0: 没有检测到系统升级<br>0x1: 检测到系统升级<br>注: 只有 UART0 有该位。只能软件清。                                                      | WC/R | 0x0 |
| 11   | TO_PEND              | <b>Time out 标志位</b><br>表示经历了 $5 * (1 \text{ start_bit} + 8 \text{ data bit} + 2 \text{ stop bit})$ 时间, 没有接收到数据。写 1 清零。<br>0x0: time out 没有出现<br>0x1: time out 出现                                             | WC/R | 0x0 |
| 10:7 | PERR                 | <b>接收数据奇偶校验出错</b><br>4bit, 分别对应 BUF 里面的 4 个数据。在读 UARTx_DATA 之前, 需要先读这个寄存器, 硬件会自动将 PERR[0] 对应你读 UARTx_DATA 获取的数据。                                                                                             | RO   | 0x0 |
| 6:4  | RX_CNT               | <b>RX BUF 有多少个数据</b><br>0x0: 0 个数据<br>0x1: 1 个数据<br>0x2: 2 个数据<br>0x3: 3 个数据<br>0x4: 4 个数据<br>Other: 无效                                                                                                      | RO   | 0x0 |
| 3    | FERR                 | <b>帧错误</b><br>表示在 STOPbit 期间检测到 RX_IN 出现了低电平。写 1 清零<br>0x0: 没有帧错误<br>0x1: 出现了帧错误                                                                                                                             | WC/R | 0x0 |
| 2    | RX_BUF_OV            | 接收 BUF 最多可以容纳 4 个 8/9bit 的数据, 接收到 4 个数据后, 如果软件还没有来得及读走, 又收到一个数据, 这个标志会起来。写 1 清零。<br>0x0: 接收了 (0~4byte) 数据<br>0x1: 接收了 (>4byte) 的数据, BUF 里面只保存最开始的 4byte, 其他丢弃                                                | WC/R | 0x0 |

|   |                  |                                                                         |    |     |
|---|------------------|-------------------------------------------------------------------------|----|-----|
| 1 | RX_BUF_NOT_EMPTY | <b>接收 BUF 不空标志位</b><br>写 1 清零<br>0x0: 接收 BUF 没有数据<br>0x1: 接收 BUF 有数据    | RO | 0x0 |
| 0 | TX_BUF_EMPTY     | <b>发送完成标志位</b><br>写 1 清零, 或者写 UARTx_DATA 清 0<br>0x0: 发送没有完成<br>0x1: 发送完 | RO | 0x0 |

#### 9.2.3.5. UART1\_TSTADR

| Bit(s) | Name     | Description                                                             | R/W | Reset |
|--------|----------|-------------------------------------------------------------------------|-----|-------|
| 31:13  | Reserved | -                                                                       | -   | -     |
| 12:0   | TSTADRT  | <b>发送 DMA 起始地址</b><br>如果是 9bit 数据, 需要 16bit 对齐;<br>如果是 8bit 数据, 可以任意配置。 | RW  | 0x0   |

#### 9.2.3.6. UART1\_RSTADR

| Bit(s) | Name     | Description                                                             | R/W | Reset |
|--------|----------|-------------------------------------------------------------------------|-----|-------|
| 31:13  | Reserved | -                                                                       | -   | -     |
| 12:0   | RSTADRT  | <b>接收 DMA 起始地址</b><br>如果是 9bit 数据, 需要 16bit 对齐;<br>如果是 8bit 数据, 可以任意配置。 | RW  | 0x0   |

#### 9.2.3.7. UART1\_TDMALEN

| Bit(s) | Name     | Description                                                                                                     | R/W | Reset |
|--------|----------|-----------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:12  | Reserved | -                                                                                                               | -   | -     |
| 11:0   | TDMALEN  | <b>计划发送 DMA byte 长度</b><br>8bit 数据模式, uart 一帧数据等于 1byte;<br>9bit 数据, uart 一帧数据等于 2byte, TDMALEN<br>需要配置成 2 的倍数。 | RW  | 0x0   |

#### 9.2.3.8. UART1\_RDMALEN

| Bit(s) | Name     | Description                                              | R/W | Reset |
|--------|----------|----------------------------------------------------------|-----|-------|
| 31:12  | Reserved | -                                                        | -   | -     |
| 11:0   | RDMALEN  | <b>计划接收 DMA byte 长度</b><br>8bit 数据模式, uart 一帧数据等于 1byte; | RW  | 0x0   |

|  |  |                                                     |  |  |
|--|--|-----------------------------------------------------|--|--|
|  |  | 9bit 数据, uart 一帧数据等于 2byte, RDMALEN<br>需要配置成 2 的倍数。 |  |  |
|--|--|-----------------------------------------------------|--|--|

### 9.2.3.9. UART1\_TDMACNT

| Bit(s) | Name     | Description                                                                      | R/W | Reset |
|--------|----------|----------------------------------------------------------------------------------|-----|-------|
| 31:12  | Reserved | -                                                                                | -   | -     |
| 11:0   | TDMACNT  | 已经发送 DMA byte 长度<br>8bit 数据模式, uart 一帧数据等于 1byte;<br>9bit 数据, uart 一帧数据等于 2byte。 | RO  | 0x0   |

### 9.2.3.10. UART1\_RDMACNT

| Bit(s) | Name     | Description                                                                      | R/W | Reset |
|--------|----------|----------------------------------------------------------------------------------|-----|-------|
| 31:12  | Reserved | -                                                                                | -   | -     |
| 11:0   | RDMACNT  | 已经接收 DMA byte 长度<br>8bit 数据模式, uart 一帧数据等于 1byte;<br>9bit 数据, uart 一帧数据等于 2byte。 | RO  | 0x0   |

### 9.2.3.11. UART1\_DMACON

| Bit(s) | Name             | Description                                                                        | R/W | Reset |
|--------|------------------|------------------------------------------------------------------------------------|-----|-------|
| 31:10  | Reserved         | -                                                                                  | -   | -     |
| 9      | RX_DMA_EN_CFG_EN | <b>RX_DMA_EN 配置使能</b><br>配置 RX_DMA_EN 时候, 这位同时写 1 才可以。自动清 0。<br>0x0: 关闭<br>0x1: 打开 | WO  | 0x0   |
| 8      | TX_DMA_EN_CFG_EN | <b>TX_DMA_EN 配置使能</b><br>配置 TX_DMA_EN 时候, 这位同时写 1 才可以。自动清 0。<br>0x0: 关闭<br>0x1: 打开 | WO  | 0x0   |
| 7: 5   | Reserved         | -                                                                                  | -   | -*    |
| 4      | RX_DMA_PERR_IE   | 接收 DMA 一包数据出现至少一个数据奇偶校验错误, 中断使能<br>0x0: 关闭<br>0x1: 打开                              | RW  | 0x0   |
| 3      | RX_DMA_IE        | <b>接收 DMA 中断使能</b><br>0x0: 关闭<br>0x1: 打开                                           | RW  | 0x0   |
| 2      | TX_DMA_IE        | <b>发送 DMA 中断使能</b>                                                                 | RW  | 0x0   |

|   |           |                                                                         |    |     |
|---|-----------|-------------------------------------------------------------------------|----|-----|
|   |           | 0x0: 关闭<br>0x1: 打开                                                      |    |     |
| 1 | RX_DMA_EN | <b>接收 DMA 使能</b><br>配置该位同时要往 RX_DMA_EN_CFG_EN 写 1<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |
| 0 | TX_DMA_EN | <b>发送 DMA 使能</b><br>配置该位同时要往 TX_DMA_EN_CFG_EN 写 1<br>0x0: 关闭<br>0x1: 打开 | RW | 0x0 |

### 9.2.3.12. UART1\_DMASTA

| Bit(s) | Name        | Description                                                                            | R/W | Reset |
|--------|-------------|----------------------------------------------------------------------------------------|-----|-------|
| 31:3   | Reserved    | -                                                                                      | -   | -     |
| 2      | RX_DMA_PERR | <b>接收 DMA 一包数据出现至少一个数据奇偶校验错误标志位</b><br>0x0: 没有数据出现奇偶校验错误<br>0x1: 出现了至少一个数据奇偶校验错误       | RC  | 0x0   |
| 1      | RX_DMA_PEND | <b>接收 DMA 完成标志位</b><br>指数据接收完成并保存到 SRAM<br>0x0: DMA 没有完成<br>0x1: DMA 已经完成              | RC  | 0x0   |
| 0      | TX_DMA_PEND | <b>发送 DMA 完成标志位</b><br>指数据从 SRAM 取出并且通过 uart 完整发送出去。<br>0x0: DMA 没有完成<br>0x1: DMA 已经完成 | RC  | 0x0   |

### 9.2.3.13. UART1\_RS485CON

| Bit(s) | Name       | Description                                                                           | R/W | Reset |
|--------|------------|---------------------------------------------------------------------------------------|-----|-------|
| 31:10  | Reserved   | -                                                                                     | -   | -     |
| 9      | RE_EN      | <b>RE 使能</b><br>0x0: 关闭<br>0x1: 打开                                                    | RW  | 0x0   |
| 8      | DE_EN      | <b>DE 使能</b><br>0x0: 关闭<br>0x1: 打开                                                    | RW  | 0x0   |
| 7:4    | Reserved   | -                                                                                     | -   | -     |
| 3      | RS485_MODE | <b>RS485 工作模式</b><br>0x0: 软件配置 DE_EN, DE 会一直有效, 直到配置 DE_EN 为 0; 软件配置 RE_EN, RE 会一直有效, | RC  | 0x0   |

|   |          |                                                                                                                                                     |    |     |
|---|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|   |          | 直到配置 RE_EN 为 0; 硬件会自动插入 DE_DAT, DE_AT, RE2DE_T, DE2RE_T 时间。这一位等于 0 的时候, DE_EN 和 RE_EN 不能同时置 1<br>0x1: 硬件自动切换 DE 和 RE 模式, 有数据需要发送切换到 DE, 没有数据发送保持 RE |    |     |
| 2 | RE_POL   | <b>RE 极性</b><br>0x0: 高电平有效<br>0x1: 低电平有效                                                                                                            | RC | 0x0 |
| 1 | DE_POL   | <b>DE 极性</b><br>0x0: 高电平有效<br>0x1: 低电平有效                                                                                                            | RW | 0x0 |
| 0 | RS485_EN | <b>RS485 使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                               | RW | 0x0 |

#### 9.2.3.14. UART1\_RS485DET

| Bit(s) | Name     | Description                               | R/W | Reset |
|--------|----------|-------------------------------------------|-----|-------|
| 31:25  | Reserved | -                                         | -   | -     |
| 24:16  | DE_DAT   | STOP BIT 结束到 DE 无效之间的时间间隔, 单位是 uart 模块时钟  | RW  | 0x0   |
| 15:9   | -        | -                                         | -   | -     |
| 8:0    | DE_AT    | DE 有效到发送 START BIT 之间的时间间隔, 单位是 uart 模块时钟 | RW  | 0x0   |

#### 9.2.3.15. UART1\_RS485TAT

| Bit(s) | Name    | Description                        | R/W | Reset |
|--------|---------|------------------------------------|-----|-------|
| 31:16  | RE2DE_T | RE 有效到 DE 有效之间的时间间隔, 单位是 uart 模块时钟 | RW  | 0x0   |
| 15:0   | DE2RE_T | DE 有效到 RE 有效之间的时间间隔, 单位是 uart 模块时钟 | RW  | 0x0   |

#### 9.2.4. 使用说明

1) DMA 模式不使能的 UART 发送:

1. 配置 UARTx\_BAUD;
2. 配置 UARTx\_CON;

- TX\_IE : 如果需要中断, 这位配 1
- TX\_INV : 如果需要将输出取反, 这位配 1
- UART\_EN : 配 1
- BIT9\_EN : 如果需要传输 9bit 数据, 这位配 1
- BIT9 : 如果 BIT9\_EN, 这位写入需要传输的第 9bit 数据
3. 配置 UART\_RS485\_CON, UART\_RS485\_DAT, UART\_RS485\_TAT;
  4. 等待 UARTx\_STA[0] (TX\_BUF\_EMPTY) 位为 1, 然后往 UARTx\_DATA 中写入需要发送的 8bit/9bit 数据
  5. 如果还有需要发送的数据, 重复 4.
  6. 如果已经没有数据需要发送, 等待所有数据发送完成: 等待 UARTx\_STA[15] : TC 置 1;
- 2) DMA 模式使能的 UART 发送:
1. 配置 UARTx\_BAUD.
  2. 配置 UARTx\_CON
- TX\_IE : 如果需要中断, 这位配 1
- TX\_INV : 如果需要将输出取反, 这位配 1
- UART\_EN : 配 1
- BIT9\_EN : 如果需要传输 9bit 数据, 这位配 1
- BIT9 : 如果 BIT9\_EN, 这位写入需要传输的第 9bit 数据
3. 配置 UART\_RS485\_CON, UART\_RS485\_DAT, UART\_RS485\_TAT;
  4. 配置 DMACON, DMA\_TSTADR, DMA\_TDLEN;
  5. 等待 DMA 完成:UART\_DMA\_CON[0]清零, 或者 UART\_DMASTA[0]为 1;

- 3) DMA 模式不使能的 UART 接收:
1. 配置 UARTx\_BAUD.
  2. 配置 UARTx\_CON
- RX\_IE : 如果需要中断, 这位配 1
- RX\_INV : 如果需要将输入取反, 这位配 1
- UART\_EN : 配 1
- BIT9\_EN : 如果需要传输 9bit 数据, 这位配 1

3. 配置 UART\_RS485\_CON, UART\_RS485\_DAT, UART\_RS485\_TAT;
  4. 等待接收到数据:接收到数据后, UARTx\_STA[1] : RX\_BUF\_NOTEMPTY 会置 1, 同时可以通过查看 UARTx\_STA[6: 4] : RX\_CNT 了解收到了多少 byte 数据。
  5. 读取接收到的数据, 通过读 UARTx\_DATA 获取接收到的数据。
  6. 如果还有数据需要接收, 重复 4 和 5.
- 4) DMA 模式使能的 UART 接收:
1. 配置 UARTx\_BAUD.
  2. 配置 UARTx\_CON
- RX\_IE : 如果需要中断, 这位配 1
- RX\_INV : 如果需要将输入取反, 这位配 1
- UART\_EN : 配 1
- BIT9\_EN : 如果需要传输 9bit 数据, 这位配 1
3. 配置 UART\_RS485\_CON, UART\_RS485\_DAT, UART\_RS485\_TAT;
  4. 配置 DMACON, DMA\_RSTADR, DMA\_RDMALEN;
  5. 等待 DMA 完成:UART\_DMA\_CON[1]清零, 或者 UART\_DMASTA[1]为 1;

## 10. CRC 计算单元

### 10.1. 主要特性

- 支持 5/7/8/16/32 等不同长度的多项式
- 支持自定义的多项式

## 10.2. 寄存器

### 10.2.1. 寄存器地址

| Name | Base Address | Description |
|------|--------------|-------------|
| CRC  | 0x40002000   | CRC 的基址     |

### 10.2.2. 寄存器列表

| Offset Address | Name     | Description |
|----------------|----------|-------------|
| 0x00           | CRC_CFG  | 配置寄存器       |
| 0x04           | CRC_INIT | 初始化配置寄存器    |
| 0x08           | CRC_INV  | 取反寄存器       |
| 0x0C           | CRC_POLY | 多项式配置寄存器    |
| 0x10           | CRC_KST  | 触发寄存器       |
| 0x14           | CRC_STA  | 状态寄存器       |
| 0x18           | CRC_ADDR | 地址寄存器       |
| 0x1C           | CRC_LEN  | 长度寄存器       |
| 0x20           | CRC_OUT  | 结果输出寄存器     |

### 10.2.3. 寄存器详细说明

#### 10.2.3.1. CRC\_CFG

| Bit(s) | Name         | Description                                                   | R/W | Reset |
|--------|--------------|---------------------------------------------------------------|-----|-------|
| 31:14  | Reserved     |                                                               | RO  | 0     |
| 13:8   | POLY_WIDTH   | <b>Poly 的位宽配置项</b><br>支持 5/7/8/16/32 的配置， 默认是 32 Bit          | RW  | 32    |
| 7:2    | Reserved     |                                                               | RO  | 0     |
| 1      | BIT_ORDER_EN | <b>输出的数据是否取反</b><br>0x0: 关闭<br>0x1: 打开, DATA[7:0] toDATA[0:7] | RW  | 0     |
| 0      | INT_EN       | <b>CRC 中断使能</b><br>0x0: 关闭                                    | RW  | 0     |

|  |  |         |  |  |
|--|--|---------|--|--|
|  |  | 0x1: 打开 |  |  |
|--|--|---------|--|--|

#### 10.2.3.2. CRC\_INIT

| Bit(s) | Name       | Description | R/W | Reset          |
|--------|------------|-------------|-----|----------------|
| 31:0   | INIT_VALUE | CRC 初始值     | RW  | 0xFFFF<br>FFFF |

#### 10.2.3.3. CRC\_INV

| Bit(s) | Name      | Description | R/W | Reset          |
|--------|-----------|-------------|-----|----------------|
| 31:0   | INV_VALUE | CRC 输出结果反转  | RW  | 0xFFFF<br>FFFF |

#### 10.2.3.4. CRC\_POLY

| Bit(s) | Name       | Description                      | R/W | Reset          |
|--------|------------|----------------------------------|-----|----------------|
| 31:0   | POLY_VALUE | 配置 CRC ploy 值<br>默认值为 0xedb88320 | RW  | 0xedb8832<br>0 |

#### 10.2.3.5. CRC\_KST

| Bit(s) | Name          | Description           | R/W | Reset |
|--------|---------------|-----------------------|-----|-------|
| 31:1   | Reserved      |                       | RW  | 0     |
| 1      | Pending Clear | 清除 CRC 的标志位<br>写 1 清除 | WO  | 0     |

#### 10.2.3.6. CRC\_STA

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:1   | Reserved |             | RO  | 0     |
| 1      | Pending  | CRC 完成标志位   | RO  | 0     |

#### 10.2.3.7. CRC\_POLY

| Bit(s) | Name       | Description                      | R/W | Reset          |
|--------|------------|----------------------------------|-----|----------------|
| 31:0   | POLY_VALUE | 配置 CRC ploy 值<br>默认值为 0xedb88320 | RW  | 0xedb8832<br>0 |

#### 10.2.3.8. CRC\_ADDR

| Bit(s) | Name              | Description                                          | R/W | Reset |
|--------|-------------------|------------------------------------------------------|-----|-------|
| 31:2   | DMA Start Address | CRC DMA 开始地址<br>注意：物理地址，比如地址为 0x0 重定向<br>0x2000_0000 | RO  | 0     |
| 1:0    | Reserved          | 保留，用于 4 byte 对齐                                      | RO  | 0     |

#### 10.2.3.9. CRC\_LEN

| Bit(s) | Name       | Description               | R/W | Reset |
|--------|------------|---------------------------|-----|-------|
| 31:0   | DMA Length | CRC DMA 长度配置<br>4 byte 对齐 | RW  | 0x0   |

#### 10.2.3.10. CRC\_OUT

| Bit(s) | Name       | Description | R/W | Reset |
|--------|------------|-------------|-----|-------|
| 31:0   | CRC Result | CRC 计算结果输出  | RO  | 0x0   |

### 10.3. 操作流程

- 2、配置 CRC 初始值(CRC\_INIT)和取反(CRC\_INV);
- 3、配置 CRC 多项式(CRC\_POLY)，CRC 多项式的位宽(CRC\_CFG);
- 4、配置 DMA 的开始地址（物理地址），最后配置 DMA 的长度，一旦长度不为 0，即开始执行 CRC 校验；
- 5、等待 CRC 的 pending(CRC\_STA) ， 得到 CRC 的结果 (CRC\_OUT) ， 最后清除 pending(CRC\_KST)。

## 11. 硬件加速单元

### 11.1. 加速单元简介

本加速单元包含一个硬件除法器。硬件除法在一些高性能的应用中非常有用，能自动执行有符号或者无符号的 32 位/16 位整数除法运算。

### 11.2. 硬件除法主要特征

- 有符号或者无符号整数除法运算
- 32 位除数和 16 位被除数，输出 32 位的商和 16 位余数
- 8 个 HCLK 周期完成
- 如果除数为零，会产生溢出中断标志位
- 写除数自动执行除法运算
- 读商和余数寄存器时自动等待运算结束，不需要检查状态位

### 11.3. 硬件除法功能介绍

硬件除法单元包括 4 个 32 位数据寄存器，分别为被除数，除数，商和余数，可以做有符号或者无符号的 16 位除法运算。通过硬件除法控制寄存器 SIGN 可以选择是有符号除法还是无符号除法。每一次写入除数寄存器，会自动触发除法运算，在运算结束后，结果会写入到商和余数寄存器里。如果在结束前读商寄存器、余数寄存器或者状态寄存器，读操作会被暂停，直到结束才返回运算结果。如果除数为零，会产生溢出中断标志位

### 11.4. 寄存器

#### 11.4.1. 寄存器基地址

| Name | Base Address | Description |
|------|--------------|-------------|
|------|--------------|-------------|

| Name | Base Address | Description |
|------|--------------|-------------|
| DIV  | 0x40020A00   | 硬件除法器基地址    |

## 11.4.2. 寄存器列表

| Offset Address | Name    | Description |
|----------------|---------|-------------|
| 0x0000         | DIV_DVD | 被除数寄存器      |
| 0x0004         | DIV_DVS | 除数寄存器       |
| 0x0008         | DIV_QUO | 商寄存器        |
| 0x000c         | DIV_Rem | 余数寄存器       |
| 0x0010         | DIV_SR  | 状态寄存器       |
| 0x0014         | DIV_CON | 控制寄存器       |

## 11.4.3. 寄存器详细说明

### 11.4.3.1. DIV\_DVD

| Bit(s) | Name     | Description             | R/W | Reset |
|--------|----------|-------------------------|-----|-------|
| 31:0   | Dividend | 被除数寄存器位 (Dividend data) | RW  | 0x0   |

### 11.4.3.2. DIV\_DVS

| Bit(s) | Name     | Description                                | R/W | Reset |
|--------|----------|--------------------------------------------|-----|-------|
| 31:16  | Reserved | -                                          | -   | -     |
| 15: 0  | DIVISOR  | 除数寄存器位 (Divisor data)<br>写完该寄存器后，自动触发除法运算。 | RW  | 0x0   |

### 11.4.3.3. DIV\_QUO

| Bit(s) | Name     | Description           | R/W | Reset |
|--------|----------|-----------------------|-----|-------|
| 31: 0  | QUOTIENT | 商寄存器位 (Quotient data) | RW  | 0x0   |

### 11.4.3.4. DIV\_Rem

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|       |           |                         |    |     |
|-------|-----------|-------------------------|----|-----|
| 31:16 | Reserved  | -                       | -  | -   |
| 15: 0 | REMAINDER | 余数寄存器位 (Remainder data) | RW | 0x0 |

#### 11.4.3.5. DIV\_SR

| Bit(s) | Name      | Description                                                        | R/W | Reset |
|--------|-----------|--------------------------------------------------------------------|-----|-------|
| 31:1   | Reserved  | -                                                                  | -   | -     |
| 0      | DIV0_FLAG | read 1:当前除法操作除数为0<br>read 0:当前除数不为0<br>写1与写DVSR均能清除这个bit<br>写0:无操作 | RW  | 0x0   |

#### 11.4.3.6. DIV\_CON

| Bit(s) | Name     | Description                         | R/W | Reset |
|--------|----------|-------------------------------------|-----|-------|
| 31:2   | Reserved | -                                   | -   | -     |
| 1      | INT_EN   | 0x0: 除数为0不产生中断信号<br>0x1: 除数为0产生中断信号 | RW  | 0x1   |
| 0      | SIGN     | 0x0: 无符号除法<br>0x1: 有符号除法            | RW  | 0x0   |

## 12. 比较器 (COMP)

### 12.1. 简介

芯片内嵌一个通用比较器 COMP，可独立使用，也可与定时器和 EPWM 结合使用。

### 12.2. 主要特性

- 轨对轨比较器
- 可复用 I/O，内部一端连接到 DAC 上
- 可编程迟滞电压
- 支持比较结果的滤波功能

- 输出端可以重定向到一个 I/O 端口
- 输出端连接到多个定时器输入端，可以触发定时器的捕获事件
- 输出端连接到多个 EPWM 输入端，可以触发 EPWM 刹车
- COMP 有 7 个正相输入和 4 个反向输入
- 比较器可产生中断，并支持把 CPU 从睡眠模式和停机模式唤醒

## 12.3. 功能描述

### 12.3.1. 比较器功能框图



图 12-1 通道结构图



图 12-2 控制结构图

### 12.3.2. 比较器输入和输出

作为比较器输入的 I/O 引脚必须在 GPIO 寄存器中设置为模拟模式。

比较器的输出可以重定向到多个 I/O 端口。

比较器的输出内部连接到多个定时器的输入：作为输入捕获，测量时序。

比较器的输出内部连接到多个 EPWM 的输入：作为刹车。

### 12.3.3. 比较器工作模式

比较器分为普通工作模式和轮询工作模式。

在普通工作模式下，比较器只能比较软件设定的通道，通过配置 CMP\_CHANO 完成操作。

软件操作流程如下：

1. 配置 CMP\_CON 寄存器，设置 DAC 和 CMP 的工作条件；
2. 配置 CMP\_CHANO 寄存器的 POLL\_INPSEL 和 POLL\_INNSEL 位选择比较的信号；
3. 配置 CMP\_CHANO 寄存器中断使能，反相使能，滤波周期，唤醒边沿以及唤醒使能；
4. 配置 CMP\_CON 寄存器的 CMPEN 位使能比较器。

在轮询工作模式下，比较器会每隔一段时间比较不同的通道，最多轮询四个通道，每个通道的输入可选择。可配置正相和反相端同时轮询，也可以选择一端轮询，另一端固定通道，通过配置 CMP\_POLL 以及 CMP\_CHAN0~3 完成操作。软件操作流程如下：

1. 配置 CMP\_CON 寄存器，设置 DAC 和 CMP 的工作条件；
2. 配置 CMP\_CHAN0~3 寄存器的 POLL\_INPSEL 和 POLL\_INNSEL 位选择比较的信号；
3. 配置 CMP\_CHAN0~3 寄存器中断使能，反相使能，滤波周期，唤醒边沿以及唤醒使能；
4. 配置 CMP\_POLL 寄存器轮询通道数，轮询周期，正相和反相轮询使能以及轮询 MASK；
5. 配置 CMP\_CON 寄存器的 CMPEN 位使能比较器。

注：poll\_num 为 0 时，默认为普通工作模式。

#### 12.3.4. 比较器滤波控制

因比较器输入端发生变化导致输出端的不稳定状态，比较器提供了两种方法对比较器输出进行滤波，数字滤波与硬件 MARK。

1. 数字滤波即直接对比较器的输出结果进行滤波 filt\_num (COMP\_CHANx 寄存器) 个时钟周期。
2. 硬件 MARK 即在 CHANNEL 的轮询周期的前 poll\_mark (COMP\_POLL 寄存器) 个时钟周期将比较器的输出屏蔽。如比较器的输出稳定需要 3 个时钟周期，可以把 poll\_mark 配成 4，硬件就取 4 个时钟周期后的比较器结果进行寄存，直接屏蔽掉不稳定的结果。

在普通工作模式下，只能使用数字滤波的方法。在轮询工作模式下，两种方法都可以使用。

#### 12.3.5. 比较器轮询周期

在轮询工作模式下，轮询周期需满足以下公式：

1. 使用数字滤波：Poll\_period >= 2 \* filt\_num + 6
  2. 使用硬件 MARK：Poll\_period >= poll\_mark + 2
- 3 同时使用需满足：①Poll\_period >= poll\_mark + 2 \* filt\_num + 6 ②Filt\_num + 5 <=

### poll\_mark

在轮询工作模式下，比较器输入端的信号保持时间需满足以下公式：

$$\text{Hold\_time} > \text{poll\_num} * \text{poll\_period}$$

**注：轮询且通道反相输出时，必须使用硬件 MARK 方式。**

### 12.3.6. 比较器中断和唤醒

比较器的输出可以内部连接到外部中断和时间控制器。比较器输出唤醒信号，能产生中断，事件或用来退出低功耗模式。

### 12.3.7. 比较器锁定机制

比较器能用于安全的用途，比如过流保护或者过热保护。在某些特定的安全需求的应用中，有必要保证比较器设置不能被无效寄存器访问或者程序计数器破坏所改变。

为了这个目的，比较器控制和状态寄存器可以设为写保护。

一旦设置完成，LOCK 位必须设为 1，这导致整个寄存器变为只读，包括 LOCK 位在内。

写保护只能被 MCU 复位清除。

### 12.3.8. 比较器迟滞现象

比较器的可配置迟滞电压能防止无效的输出变化产生的噪声信号。在不需要强制迟滞电压的情况下迟滞现象可以被禁止。

## 12.4. 寄存器

### 12.4.1. 寄存器基地址

| Name | Base Address | Description |
|------|--------------|-------------|
| COMP | 0x40010200   | 比较器基地址      |

## 12.4.2. 寄存器列表

| Offset Address | Name       | Description |
|----------------|------------|-------------|
| 0x0000         | COMP_CON   | 控制寄存器       |
| 0x0004         | COMP_POLL  | 轮询寄存器       |
| 0x0008         | COMP_CHAN0 | 通道 0 寄存器    |
| 0x000c         | COMP_CHAN1 | 通道 1 寄存器    |
| 0x0010         | COMP_CHAN2 | 通道 2 寄存器    |
| 0x0014         | COMP_CHAN3 | 通道 3 寄存器    |
| 0x0018         | COMP_CLR   | 清除寄存器       |
| 0x001C         | COMP_STA   | 状态寄存器       |

## 12.4.3. 寄存器详细说明

### 12.4.3.1. COMP\_CON

| Bit(s) | Name    | Description                                                                                          | R/W | Reset |
|--------|---------|------------------------------------------------------------------------------------------------------|-----|-------|
| 31     | Lock    | <b>比较器锁</b><br>该位只能写一次，由软件置“1”，由系统复位清零。<br>它令比较器的所有控制位为只读。<br>0x0: COMP_CON 可读可写<br>0x1: COMP_CON 只读 | RW  | 0x0   |
| 30:29  | reserve | -                                                                                                    | -   | -     |
| 28:21  | Dak     | DAC 数据输入                                                                                             | RW  | 0x0   |
| 20:19  | Cmpyst  | <b>CMP 迟滞功能选择</b><br>0x0: 没有迟滞<br>0x1: 20mV<br>0x2: 40mV<br>0x3: 70mV                                | RW  | 0x0   |
| 18:17  | Cmpimir | <b>CMP 偏置电流比例</b><br>0x0: 2:1<br>0x1: 3:1<br>0x2: 4:1<br>0x3: 5:1                                    | RW  | 0x2   |
| 16:15  | Cmpmode | <b>比较器工作模式选择</b><br>0x0: 最低功耗模式<br>0x1: 此低功耗模式                                                       | RW  | 0x2   |

|       |          |                                                                                                                           |    |     |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------|----|-----|
|       |          | 0x2: 常规模式<br>0x3: 最高速模式                                                                                                   |    |     |
| 14:13 | Daflres  | <b>DAC Filter res select</b><br>0x0: 0<br>0x1: 10K<br>0x2: 20K<br>0x3: 30K                                                | RW | 0x0 |
| 12:11 | Dafssel  | <b>8 bit DAC 量程选择</b><br>0x0: 1.6V<br>0x1: 2.4V<br>0x2: 3.2V<br>0x3: 4.8V                                                 | RW | 0x0 |
| 10:8  | Isumres  | <b>比较器正相输入端 Fitter RES select</b><br>0x0: 50K<br>0x1: 100K<br>0x2: 150K<br>0x3: 200K<br>Other: bypass RES<br>滤波电容约 3.5 pf | RW | 0x6 |
| 7     | Cmpen    | <b>比较器使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                        | RW | 0x0 |
| 6     | Cmpnen   | <b>CMP 反相输入</b><br>0x0: 关闭<br>0x1: 打开                                                                                     | RW | 0x1 |
| 5     | Cmppen   | <b>CMP 正相输入</b><br>0x0: 关闭<br>0x1: 打开                                                                                     | RW | 0x1 |
| 4     | Dabitsel | <b>DAC 模式选择</b><br>0x0: 8 bit<br>0x1: 5 bit                                                                               | RW | 0x1 |
| 3     | Dacoutsw | <b>DAC 输出到 GPIO</b><br>0x0: 关闭<br>0x1: 打开                                                                                 | RW | 0x0 |
| 2     | Daen     | <b>DAC 使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                       | RW | 0x0 |
| 1     | Dafpen   | <b>8 bit DAC fast path enable</b><br>0x0: 关闭<br>0x1: 打开                                                                   | RW | 0x0 |
| 0     | Darefsel | <b>5 bit DAC 参考源（量程）选择</b><br>0x0: inside ref, 1.2V<br>0x1: outside ref                                                   | RW | 0x1 |

#### 12.4.3.2. COMP\_POLL

| Bit(s) | Name        | Description                                                                                            | R/W | Reset |
|--------|-------------|--------------------------------------------------------------------------------------------------------|-----|-------|
| 31     | lock        | <b>比较器锁</b><br>该位只能写一次，由软件置“1”，由系统复位清零。<br>它令比较器的所有控制位为只读。<br>0x0: COMP_POLL 可读可写<br>0x1: COMP_POLL 只读 | RW  | 0x0   |
| 30:12  | reserved    | -                                                                                                      | -   | -     |
| 11:7   | Poll_mark   | <b>通道 mark 周期</b><br>0x00: 禁止 mark<br>0x01: 1 CMP CLK<br>0x02: 2 CMP CLK<br>...<br>0x1F: 31 CMP CLK    | RW  | 0x0   |
| 6:5    | Poll_num    | <b>每个轮询通的通道数</b><br>0x0: 1 个通道<br>0x1: 2 个通道<br>0x2: 3 个通道<br>0x3: 4 个通道                               | RW  | 0x0   |
| 4:2    | Poll_period | <b>轮询周期</b><br>0x0: 1 CMP CLK<br>0x1: 2 CMP CLK<br>0x2: 4 CMP CLK<br>...<br>0x7: 128 CMP CLK           | RW  | 0x0   |
| 1      | npoll_en    | <b>反相端轮询使能</b><br>0x0: 关闭<br>0x1: 打开                                                                   | RW  | 0x0   |
| 0      | ppoll_en    | <b>正相端轮询使能</b><br>0x0: 关闭<br>0x1: 打开                                                                   | RW  | 0x0   |

#### 12.4.3.3. COMP\_CHANx

| Bit(s) | Name        | Description                                                                                              | R/W | Reset |
|--------|-------------|----------------------------------------------------------------------------------------------------------|-----|-------|
| 31     | Lock        | <b>比较器锁</b><br>该位只能写一次，由软件置“1”，由系统复位清零。<br>它令比较器的所有控制位为只读。<br>0x0: COMP_CHAN0 可读可写<br>0x1: COMP_CHAN0 只读 | RW  | 0x0   |
| 30:16  | Reserve     | -                                                                                                        | -   | -     |
| 15:13  | poll_innsel | < 2 >通道 x 使能位                                                                                            | RW  | 0x0   |

|       |              |                                                                                                                                                                           |    |     |
|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|       |              | 0x0: 关闭<br>0x1: 打开<br><b>&lt;1:0&gt;反相端通道 x 的输入选择</b><br>0x0: PA9<br>0x1: PA10<br>0x2: PA11<br>0x3: DAC                                                                   |    |     |
| 12:10 | poll_inpsel  | <b>正相端通道 x 的输入选择</b><br>0x0: PA0<br>0x1: PA3<br>0x2: PA5<br>0x3: PA6<br>0x4: AMP_VOUT1(运放 1 输出)<br>0x5: AMP_VOUT2(运放 2 输出)<br>0x6: AMP_VOUT3(运放 3 输出)<br>0x7: 断开与 GPIO 连接 | RW | 0x0 |
| 9:8   | Cpu_wkup_sel | <b>唤醒边沿选择</b><br>0x0: 比较器 0 上升沿唤醒<br>0x1: 比较器 0 下降沿唤醒<br>0x2: 比较器上升沿和下降沿都能唤醒<br>others: 保留                                                                                | RW | 0x0 |
| 7:3   | filt_num     | <b>滤波周期</b><br>0x00: OCMP CLK<br>0x01: 1 CMP CLK<br>0x02: 2 CMP CLK<br>..<br>0x1F: 31 CMP CLK                                                                             | RW | 0x0 |
| 2     | Inv_en       | <b>反相使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                         | RW | 0x0 |
| 1     | wkup_en      | <b>唤醒使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                         | RW | 0x0 |
| 0     | Int_en       | <b>通道 x 中断使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                    | RW | 0x0 |

#### 12.4.3.4. COMP\_CLR

| Bit(s) | Name         | Description          | R/W | Reset |
|--------|--------------|----------------------|-----|-------|
| 31:4   | reserved     | -                    | -   | -     |
| 3      | Ch3_pend_clr | 写 1 清除比较器通道 3 输出标志信号 | WO  | 0x0   |
| 2      | Ch2_pend_clr | 写 1 清除比较器通道 2 输出标志信号 | WO  | 0x0   |
| 1      | Ch1_pend_clr | 写 1 清除比较器通道 1 输出标志信号 | WO  | 0x0   |
| 0      | Ch0_pend_clr | 写 1 清除比较器通道 0 输出标志信号 | WO  | 0x0   |

#### 12.4.3.5. COMP\_STA

| Bit(s) | Name     | Description    | R/W | Reset |
|--------|----------|----------------|-----|-------|
| 31:4   | reserved | -              | -   | -     |
| 3      | Ch3_pend | 比较器通道 3 输出标志信号 | RO  | 0x0   |
| 2      | Ch2_pend | 比较器通道 2 输出标志信号 | RO  | 0x0   |
| 1      | Ch1_pend | 比较器通道 1 输出标志信号 | RO  | 0x0   |
| 0      | Ch0_pend | 比较器通道 0 输出标志信号 | RO  | 0x0   |

## 13. 运算放大器 (OPA)

### 13.1. 简介

芯片内嵌三个运算放大器，运算放大器的输入和输出都连接到 I/O，通过共享 I/O 可以与 ADC、比较器相连。

### 13.2. 主要特征

- 轨对轨输入/输出
- 输出连接到 I/O 上

### 13.3. 寄存器描

#### 13.3.1. 寄存器地址

| Name | Base Address | Description |
|------|--------------|-------------|
| AMP  | 0x4002006C   | 运放地址        |

#### 13.3.2. 寄存器列表

| Offset | Address | Name | Description |
|--------|---------|------|-------------|
|--------|---------|------|-------------|

|        |          |         |
|--------|----------|---------|
| 0x0000 | AMP_CON0 | 控制寄存器 0 |
| 0x0004 | AMP_CON1 | 控制寄存器 1 |

### 13.3.3. 寄存器详细说明

#### 13.3.3.1. AMP\_CON0

| Bit(s) | Name     | Description                                                                                                    | R/W | Reset |
|--------|----------|----------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:27  | qcsel3   | <b>AMP3 filter cap 选择</b><br>0x01: 300fp<br>0x02: 300fp<br>0x04: 400fp<br>0x08: 400fp<br>0x10: 600fp           | R/W | 0x1   |
| 26:24  | gainsel3 | <b>AMP3 gain 选择</b><br>0x0: x4<br>0x1: x6<br>0x2: x8<br>0x3: x10<br>0x4: x12<br>0x5~0x7: disable feedback loop | R/W | 0x2   |
| 23:19  | qcsel2   | <b>AMP2 filter cap 选择</b><br>0x01: 300fp<br>0x02: 300fp<br>0x04: 400fp<br>0x08: 400fp<br>0x10: 600fp           | R/W | 0x1   |
| 18:16  | gainsel2 | <b>AMP2 gain 选择</b><br>0x0: x4<br>0x1: x6<br>0x2: x8<br>0x3: x10<br>0x4: x12<br>0x5~0x7: disable feedback loop | R/W | 0x2   |
| 15:11  | qcsel1   | <b>AMP1 filter cap 选择</b><br>0x01: 300fp<br>0x02: 300fp<br>0x04: 400fp<br>0x08: 400fp<br>0x10: 600fp           | R/W | 0x1   |
| 10:8   | gainsel1 | <b>AMP1 gain 选择</b><br>0x0: x4                                                                                 | R/W | 0x2   |

|   |            |                                                                              |     |     |
|---|------------|------------------------------------------------------------------------------|-----|-----|
|   |            | 0x1: x6<br>0x2: x8<br>0x3: x10<br>0x4: x12<br>0x5-0x7: disable feedback loop |     |     |
| 7 | ampldo_en  | <b>AMP LDO 使能</b><br>0x0: 关闭<br>0x1: 打开                                      | R/W | 0x0 |
| 6 | bias_en    | <b>BIAS 使能</b><br>0x0: 关闭<br>0x1: 打开                                         | R/W | 0x0 |
| 5 | biasadd_en | <b>BIASADD 使能</b><br>0x0: 关闭<br>0x1: 打开                                      | R/W | 0x0 |
| 4 | rcchan_en  | <b>RCCHAN 使能</b><br>0x0: 关闭<br>0x1: 打开                                       | R/W | 0x0 |
| 3 | vcmbuff_en | <b>VCMBUFF 使能</b><br>0x0: 关闭<br>0x1: 打开                                      | R/W | 0x0 |
| 2 | amp3_en    | <b>AMP3 使能</b><br>0x0: 关闭<br>0x1: 打开                                         | R/W | 0x0 |
| 1 | amp2_en    | <b>AMP2 使能</b><br>0x0: 关闭<br>0x1: 打开                                         | R/W | 0x0 |
| 0 | amp1_en    | <b>AMP1 使能</b><br>0x0: 关闭<br>0x1: 打开                                         | R/W | 0x0 |

### 13.3.3.2. AMP\_CON1

| Bit(s) | Name        | Description                                                           | R/W | Reset |
|--------|-------------|-----------------------------------------------------------------------|-----|-------|
| 31:13  | Reserved    | -                                                                     | -   | -     |
| 12     | vout2pad_en | <b>AMP2 输出到 PB2 使能</b><br>0x0: 关闭<br>0x1: 打开                          | R/W | 0x0   |
| 11     | vout1pad_en | <b>AMP1 输出到 PB1 使能</b><br>0x0: 关闭<br>0x1: 打开                          | R/W | 0x0   |
| 10:9   | rcrsel      | <b>AMP3 RC 滤波电阻选择</b><br>0x0: 1K<br>0x1: 10K<br>0x2: 50K<br>0x3: 100K | R/W | 0x0   |

|     |          |                                                                                                                                |     |     |
|-----|----------|--------------------------------------------------------------------------------------------------------------------------------|-----|-----|
| 8:6 | restrim3 | <b>AMP3 feedback 配置</b><br>0x0: 1.17X<br>0x1: 1.05X<br>0x2: 1X<br>0x3: 0.95X<br>0x4: 0.87X<br>0x5 – 0x7: disable feedback loop | R/W | 0x2 |
| 5:3 | restrim2 | <b>AMP2 feedback 配置</b><br>0x0: 1.17X<br>0x1: 1.05X<br>0x2: 1X<br>0x3: 0.95X<br>0x4: 0.87X<br>0x5 – 0x7: disable feedback loop | R/W | 0x2 |
| 2:0 | restrim1 | <b>AMP1 feedback 配置</b><br>0x0: 1.17X<br>0x1: 1.05X<br>0x2: 1X<br>0x3: 0.95X<br>0x4: 0.87X<br>0x5 – 0x7: disable feedback loop | R/W | 0x2 |

## 14. ADC

### 14.1. 功能简介

该模块是一个12bit的逐次逼近式的ADC控制器。ADC支持多种工作模式：单次转换和连续转换，可选择通道自动扫描，以及多通道触发扫描。ADC的启动包括软件启动、外部引脚触发以及其他片内外设启动（timer触发启动、epwm）。

### 14.2. 主要特征

- 最高12位可编程分辨率的SAR ADC，多达13路外部输入通道和5路内部通道
- 高达1.2Msps转换速率
- 支持多种工作模式
  - ✓ 单次转换模式：A/D转换在指定通道完成一次转换
  - ✓ 单周期扫描模式：A/D转换在所有指定通道完成一个周期（从低序号通道到高序号通道或者从高序号通道到低序号通道）转换

- ✓ 连续扫描模式：A/D转换连续执行单周期扫描模式直到软件停止A/D转换
- ✓ 多通道独立触发模式：可配置6个通道，每个通道独立触发源，触发启动A/D采样  
通道采样时间，分辨率可软件配置  
支持DMA传输。
- A/D转换开始条件
  - ✓ 软件启动
  - ✓ 外部IO触发启动
  - ✓ 内部timer触发启动
  - ✓ 内部epwm触发启动

### 14.3. 结构框图



图 14-1 ADC 功能结构图

## 14.4. 功能描述

### 14.4.1. ADC 开关控制

通过设置 ADCFG 寄存器的 ADEN 位可给 ADC 上电。当第一次设置 ADEN 位时，它将 ADC 从断电状态下唤醒。ADC 上电延迟一段时间后 (tSTAB)，设置采样模式、通道之后，设置 ADST 位开始进行转换。通过清除 ADST 位可以停止转换，设置 ADEN 位可置于断电模式。

### 14.4.2. 通道选择

包含 15 路外部输入通道、内部温度传感器通道和内部 1.2V 参考电压通道。每个外部输入通道都有独立的使能位，可通过设置 ADCHS 寄存器的对应位来设置。

### 14.4.3. ADC 工作模式

#### 14.4.3.1. 单次转换模式

在单次转换模式下，A/D 转换相应通道上只执行一次，具体流程如下：

- 软件配置转换模式 ADMD 为 0，使能 ADEN。
- 配置 TRGCONO 寄存器 PADSEL0 和 INSSEL0 选择采样通道。
- 通过软件将 ADST 置 1 启动 ADC。
- 当 A/D 转换完成，A/D 转换的数据值将存储于 A/D 的数据寄存器 ADC\_DATA0 中。
- A/D 转换完成，状态寄存器 ADC\_STA 的 DONE0 位置 ‘1’。若此时控制寄存器 ADC\_IE 的 TRGIE0 位置 ‘1’，将产生 AD 转换结束中断请求。
- A/D 转换期间，ADST 位保持为 1。A/D 转换结束，ADST 位自动清 0，A/D 转换器进入空闲模式。

#### 14.4.3.2. 单周期扫描模式

在单周期扫描模式下，将进行一次从被使能的最小序号通道向最大序号通道的 A/D 转换，可通过配置寄存器位 SCAN\_DIR 选择扫描通道方向，操作步骤如下：

- 软件配置转换模式 ADMD 为 1，使能 ADEN。
- 配置 DMA 基地址、长度，使能 DMAEN。
- 配置 ADC\_CHS 选择采样通道。
- 软件将 ADST 置 1、或外部触发置位 ADST 启动 ADC，外部触发只能通过 TRGCONO 来配置。可软件配置启动延时。
- 每路 A/D 转换完成后，A/D 转换数值将有序装载到相应的 SRAM 中，ADC\_STA 的 DONE0 转换结束标志被设置，如果设置了转换结束中断，则在所有通道转换都完成后产生中断请求。
- 转换结束后，ADST 位自动清 0，A/D 转换器进入空闲状态。

#### 14.4.3.3. 连续扫描模式

在连续扫描模式下，A/D 转换在 ADCHS 寄存器中的 CHEnn 位被使能的通道上顺序进行（可通过配置寄存器位 SCAN\_DIR 选择扫描通道方向），操作步骤如下：

- 软件配置转换模式 ADMD 为 2，使能 ADEN。
- 配置 DMA 基地址、长度，使能 DMAEN。
- 配置 ADC\_CHS 选择采样通道。
- 软件将 ADST 置 1 启动 ADC。
- 每路 A/D 转换完成后，A/D 转换数值将有序装载到相应的 SRAM 中。
- 当所有通道的 A/D 转换完成一轮后，ADC\_STA 的 DONE0 转换结束标志被置 1；当 ADST 位被清 0，该 DONE0 标志位也会被置 1。
- 只要 ADST 位保持为 1，ADC 按照 SCANDIR 重复扫描采样通道。当 ADST 位被清 0 时，硬件等待当前 channel A/D 转换完成后停止。

#### 14.4.3.4. 多通道独立触发模式

该模式可同时选择启动 1~3 个独立通道，通过 TRGCONx 的 PADSELx 和 INSSELx 来选择对应的 ADC 采样通道，并且每个通道的采样触发源可通过 TRGCONx 的 SRCSELx 寄存器选择。操作步骤如下：

- 软件配置转换模式 ADMD 为 3，使能 ADEN。
- 配置 TRGCONx 的 PADSELx 和 INSSELx 选择对应采样通道。
- 配置 TRGCONx 的 SRCSELx 选择采样触发源。
- 配置 TRGCONx 的 KICKSMPx 启动采样，或者通过触发源启动采样。
- 配置 TRGCONx 的 TRGENx 选择触发使能。
- 读取 ADC\_STA 对应的 DONEx 位和 ADC\_DATAx 得到对应的 ADC 采样数据。

#### 14.4.4. DMA 请求

单周期扫描和连续扫描时最近一次转换的结果会保存在 ADDATA 寄存器中。DMA 传输时传输所有扫描通道的结果顺序存放到对应 SRAM 中，通过 ADC\_DMAADDR 和 ADC\_DMALEN 配置 dma 起始地址和长度，并且由 DATCNT 寄存器指示存放的采样个数。

#### 14.4.5. 采样频率设置

ADC 的时钟 ADCLK 由 PCLK 分频得到，分频系数可通过设置 ADCFG 寄存器的 ADCPRE 位来确定，即 PCLK/(N+1) 分频后作为 ADC 时钟。

$$\text{ADC 最快采样率} = F_{\text{clk}} / (\text{ADCPRE} + 1) / 20$$

#### 14.4.6. 连续采样间隔时间可配置

对于连续扫描模式，连续两个通道采样之间可以配置采样延时（即在一个通道扫描完成之后，等待一

段时间再进行下一通道扫描）。

#### 14.4.7. 外部触发转换

ADC 转换可以由外部事件触发（例如定时器、IO）。如果设置了 ADC\_TRGCONx 寄存器的 TRGENx 位，就可以使用外部事件触发转换。通过设置 SRCSELx 位可以选择外部触发源。

具体的外部触发源选择情况，可以参考 ADC\_TRGCONx 控制寄存器的描述。

外部触发可设置延时控制，具体参考 ADC\_CR 的 TRGSHIFT 的描述。

在触发信号产生后，延时 N 个 PCLK 的时钟周期再开始采样。如果是触发扫描模式，则只有第一个通道采样被延时，其他通道是在上一个采样结束后立即开始。

### 14.5. ADC 接口时序



图 14-2 ADC 时序图

N: 采样周期（高速），可配置 FSMPCYC “4~31”，至少 5 个 ADCCLK

M: 采样周期（低速），可配置 SSMPYCYC “4~31”，至少 5 个 ADCCLK

k: 转换时间，可配置 RSLTCYC “9~13”

J: 通道保持时间，可配置 CHHOLDCYC “3~RSLTCYC”，至少 4 个 ADCCLK

L: 通道建立时间，可配置 CHSETUPCYC “3~(RSLTCYC-CHHOLDCYC)”

P: 连续采样间隔时间，可配置 D2DCYC “0~15” 至少 1 个 ADCCLK

#### 14.5.1. ADC 上电时序

| 延时时间 | 使能信号 |
|------|------|
|------|------|

|       |                |
|-------|----------------|
| 100us | BIASEN_VDD     |
| 300us | VCMEN_VDD      |
| 100us | CMPEN_VDD      |
| 100us | ADCEN_VDD      |
| 500us | SOC_VDD/CK_VDD |

## 14.6. 寄存器

### 14.6.1. 寄存器基地址

| Name | Base Address | Description |
|------|--------------|-------------|
| ADC  | 0x40000200   | ADC 基地址     |

### 14.6.2. 寄存器列表

| Offset Address | Name        | Description |
|----------------|-------------|-------------|
| 0x0000         | ADC_CFG0    | 配置寄存器 0     |
| 0x0004         | ADC_CFG1    | 配置寄存器 1     |
| 0x0008         | ADC_TRGCON0 | 触发寄存器 0     |
| 0x000c         | ADC_TRGCON1 | 触发寄存器 1     |
| 0x0010         | ADC_TRGCON2 | 触发寄存器 2     |
| 0x0014         | ADC_TRGCON3 | 触发寄存器 3     |
| 0x0018         | ADC_TRGCON4 | 触发寄存器 4     |
| 0x001c         | ADC_TRGCON5 | 触发寄存器 5     |
| 0x0020         | ADC_CR      | 控制寄存器       |
| 0x0024         | ADC_CHS     | 通道寄存器       |
| 0x0028         | ADC_IE      | 中断寄存器       |
| 0x002c         | ADC_STA     | 状态寄存器       |
| 0x0030         | ADC_DATA0   | 数据寄存器 0     |
| 0x0034         | ADC_DATA1   | 数据寄存器 1     |
| 0x0038         | ADC_DATA2   | 数据寄存器 2     |
| 0x003c         | ADC_DATA3   | 数据寄存器 3     |

|        |             |           |
|--------|-------------|-----------|
| 0x0040 | ADC_DATA4   | 数据寄存器 4   |
| 0x0044 | ADC_DATA5   | 数据寄存器 5   |
| 0x0048 | ADC_DMAADDR | DMA 地址寄存器 |
| 0x004c | ADC_DMACNT  | DMA 计数寄存器 |
| 0x0050 | ADC_DMALEN  | DMA 长度寄存器 |
| 0x0054 | ADC_ANACON  | 模拟控制寄存器   |
| 0x0058 | ADC_ANAPAR0 | 模拟配置寄存器 0 |
| 0x005c | ADC_ANAPAR1 | 模拟配置寄存器 1 |
| 0x0060 | ADC_ANAPAR2 | 模拟配置寄存器 2 |

### 14.6.3. 寄存器详细说明

#### 14.6.3.1. ADC\_CFG0

| Bit(s) | Name      | Description                                                                                                                      | R/W | Reset |
|--------|-----------|----------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:28  | CHHOLDCYC | 通道保持时间<br>N=n+1 个 ADC clock 周期宽度                                                                                                 | RW  | 0x3   |
| 27:23  | CHSETCYC  | 通道建立时间<br>N=n+1 个 ADC clock 周期宽度                                                                                                 | RW  | 0xA   |
| 22:18  | Reserve   | -                                                                                                                                | -   | -     |
| 17:13  | FSMPCYC   | 高速采样时间配置<br>N=n+1 个 ADC clock 周期宽度                                                                                               | RW  | 0x4   |
| 12:8   | RSLTCYC   | 转换周期配置 (影响数据有效精度)<br>N=n+1 个时钟周期宽度, n 为 ADC 转换数据分辨率<br>5' h9: 8 位有效 5' ha: 9 位有效<br>5' hb: 10 位有效 5' hc: 11 位有效<br>5' hd: 12 位有效 | RW  | 0xD   |
| 7:0    | ADCPRE    | ADC 时钟预分频 (ADC prescaler)<br>n = (n+1) 分频                                                                                        | RW  | 0x3   |

#### 14.6.3.2. ADC\_CFG1

| Bit(s) | Name     | Description                        | R/W | Reset |
|--------|----------|------------------------------------|-----|-------|
| 31:27  | Reserved | -                                  | -   | -     |
| 26:18  | SSMPCYC  | 低速采样时间配置<br>N=n+1 个 ADC clock 周期宽度 | RW  | 0x4   |

|    |           |                                                                                                                                                      |    |     |
|----|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
| 17 | SMPCSEL17 |                                                                                                                                                      | RW | 0x0 |
| 16 | SMPCSEL16 |                                                                                                                                                      | RW | 0x0 |
| 15 | SMPCSEL15 |                                                                                                                                                      | RW | 0x0 |
| 14 | SMPCSEL14 |                                                                                                                                                      | RW | 0x0 |
| 13 | SMPCSEL13 |                                                                                                                                                      | RW | 0x0 |
| 12 | SMPCSEL12 |                                                                                                                                                      | RW | 0x1 |
| 11 | SMPCSEL11 |                                                                                                                                                      | RW | 0x1 |
| 10 | SMPCSEL10 |                                                                                                                                                      | RW | 0x1 |
| 9  | SMPCSEL9  |                                                                                                                                                      | RW | 0x1 |
| 8  | SMPCSEL8  |                                                                                                                                                      | RW | 0x1 |
| 7  | SMPCSEL7  |                                                                                                                                                      | RW | 0x1 |
| 6  | SMPCSEL6  |                                                                                                                                                      | RW | 0x1 |
| 5  | SMPCSEL5  |                                                                                                                                                      | RW | 0x1 |
| 4  | SMPCSEL4  |                                                                                                                                                      | RW | 0x1 |
| 3  | SMPCSEL3  |                                                                                                                                                      | RW | 0x1 |
| 2  | SMPCSEL2  |                                                                                                                                                      | RW | 0x1 |
| 1  | SMPCSEL1  |                                                                                                                                                      | RW | 0x1 |
| 0  | SMPCSEL0  | <b>通道采样速度选择</b><br>0x0: 低速<br>0x1: 高速<br>[12:0] 对应外部通道 AINPAD[12:0]<br>[17:13] 对应内部通道 AIN[4:0]<br>0=低速, 对应通道的采样周期为 SSMPYC<br>1=高速, 对应通道的采样周期为 FSMPYC | RW | 0x1 |

#### 14.6.3.3. ADC\_TRGCON0/1/2/3/4/5

| Bit(s) | Name     | Description                                                                                                                                                                                                                                         | R/W | Reset |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | Reserved | -                                                                                                                                                                                                                                                   | -   | -     |
| 15     | OUTSEL   | ADC 结果输出范围选择<br>0x0: [0, 2^12-1]<br>0x1: [-2^11, 2^11-1]                                                                                                                                                                                            | RW  | 0x0   |
| 14:13  | Reserved | -                                                                                                                                                                                                                                                   | -   | -     |
| 12:8   | CHANSEL  | 采样通道选择:<br>0x0: AINPAD[0] = AMP_VOUT1<br>0x1: AINPAD[1] = AMP_VOUT2<br>0x2: AINPAD[2] = AMP_VOUT3<br>0x3: AINPAD[3] = PA2<br>0x4: AINPAD[4] = PA5<br>0x5: AINPAD[5] = PA8<br>0x6: AINPAD[6] = PA9<br>0x7: AINPAD[7] = PA10<br>0x8: AINPAD[8] = PA11 | RW  | 0x0   |

|     |          |                                                                                                                                                                                                                                                                                                                                                              |    |     |
|-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |          | 0x9: AINPAD[9] = PA12<br>0xA: AINPAD[10] = PA13<br>0xB: AINPAD[11] = PA14<br>0xC: AINPAD[12] = PB3<br>0xD: AIN[0] = 选择内部 PLL_CPOUT_ADC<br>0xE: AIN[1] = 选择内部 PMU_VPTAT<br>0xF: AIN[2] = 选择内部 PMU_VREF_BGBUF<br>0x10: AIN[3] = 选择内部 vdd 电压<br>0x11: AIN[4] = 选择内部 0.5*VCCA 电压<br>0x12~0x1F: 不选择任何通道                                                           |    |     |
| 7:4 | SRCSELx  | 通道触发源选择<br>0x0: epwn0_socA<br>0x1: epwn0_socB<br>0x2: epwn1_socA<br>0x3: epwn1_socB<br>0x4: epwn2_socA<br>0x5: epwn2_socB<br>0x6: epwn3_socA<br>0x7: epwn3_socB<br>0x8: timer1<br>0x9: timer2<br>0xA: timer3<br>0xB: timer4<br>0xC: timer5<br>0xD: adkey_trgio0 = TRG13_SEL ?timer0 :PA11;<br>0xE: adkey_trgio1 = PA14<br>0xF: software KICKSMPx<br>触发条件为上升沿 | RW | 0xC |
| 3   | TRGENx   | 触发通道使能<br>高电平有效<br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                                                                                                                        | RW | 0x0 |
| 2:1 | Reserved | -                                                                                                                                                                                                                                                                                                                                                            | -  | -   |
| 0   | KICKSMPx | 软件使能采样<br>高电平有效<br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                                                                                                                        | WO | 0x0 |

Note: 当前有 3 个触发采样通道，每个寄存器配置对应的通道。优先级：TRG0 > TRG1 > TRG2

#### 14.6.3.4. ADC\_CR

| Bit(s) | Name      | Description                             | R/W | Reset |
|--------|-----------|-----------------------------------------|-----|-------|
| 31:22  | Reserved  | -                                       | -   | -     |
| 21:20  | CAL_CTRL1 | ADC 通路 PAD[3]~PAD[12], AIN[0]~AIN[4] 校准 | RW  | 0x1   |

|       |           |                                                                                                                                                                                                                                             |    |     |
|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|       |           | 控制位<br>0x0: ADC 结果 Bypass<br>0x1: ADC 结果做 ADC 校准, 且校准参数值选择 eflash 中的初始化数据<br>0x3: ADC 结果做 ADC 校准, 且校准参数值选择 软件配置值 ADC_ANAPARO                                                                                                                |    |     |
| 19:17 | CAL_CTRL0 | ADC 通路 PAD[0], PAD[1], PAD[2] 校准控制位<br>0x0: ADC 结果 Bypass<br>0x1: ADC 结果只做 ADC 校准, 且校准参数值选择 eflash 中的初始化数据<br>0x3: ADC 结果做 ADC+AMP 校准, 且 AMP Gain 值选择 eflash 中的初始化数据<br>0x7: ADC 结果做 ADC+AMP 校准, 且 AMP Gain 值选择软件配置值 ADC_ANAPAR1/2          | RW | 0x3 |
| 16    | SW_RST    | 软件复位模块内部状态机, 高电平有效                                                                                                                                                                                                                          | WO | 0x0 |
| 15:12 | D2DCYC    | 两次连续采样之间的间隔时间周期, N=n+1 个 ADC clock 周期宽度                                                                                                                                                                                                     | RW | 0x0 |
| 11    | Reserved  |                                                                                                                                                                                                                                             | -  | -   |
| 10:8  | TRGSHIFT  | 外部触发延时采样 (External trigger shift sample)<br>在触发信号产生后, 延时 N 个 PCLK 的时钟周期再开始采样。<br>0x0: 不延时 1: 4 个周期<br>0x2: 8 个周期 3: 16 个周期<br>0x4: 32 个周期 5: 64 个周期<br>0x6: 128 个周期 7: 256 个周期                                                              | RW | 0x0 |
| 7     | SCANDIR   | ADC 扫描通道顺序 (ADC scan direction)<br>在周期扫描或者连续扫描方式时, 设置扫描通道的顺序<br>0x0: ADC 通道选择寄存器按从低到高的顺序扫描<br>即 :<br>PAD[0], PAD[1]...PAD[12], IN[0], IN[2]...IN[4]<br>0x1: ADC 通道选择寄存器按从高到低的顺序扫描<br>即 :<br>IN[4], IN[3]...IN[0], PAD[12], PAD[11]...PAD[0] | RW | 0x0 |
| 6     | TRG13_SEL | 触发源 13 选择位:<br>0x0: 选择 IOPA11 触发<br>0x1: 选择 time1 触发                                                                                                                                                                                        | RW | 0x0 |
| 5     | TESTMD    | 将内部 AIN[0]~AIN[4] 的电压导通到 PA2, 仅供测 试 使用 , AIN[0]~AIN[4] 选 择 由 ADC_TRGCON0[12:8] 配置<br>0x0: test 无效, ADC 正常工作                                                                                                                                 | RW | 0x0 |

|     |       |                                                                                                                                                                                                                     |    |     |
|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |       | 0x1: test 有效, ADC 不工作                                                                                                                                                                                               |    |     |
| 4:3 | ADMD  | A/D 转换模式 (ADC mode)<br>0x0: 单次转换<br>0x1: 周期扫描<br>0x2: 连续扫描<br>0x3: 触发模式<br>当改变转换模式时, 软件要先禁用 ADST 位。                                                                                                                 | RW | 0x0 |
| 2   | ADST  | ADST: A/D 转换开始 (ADC start)<br>0x0: 转换结束或进入空闲状态<br>0x1: 转换开始<br>ADST 置位有下列两种方式:<br>在单次模式或者单周期模式下, 转换完成后,<br>ADST 将被硬件自动清除;<br>在连续扫描模式下, A/D 转换将一直进行, 直到<br>软件写 0 到该位或系统复位。<br><b>单次转换、周期扫描、连续扫描使用该位启动<br/>ADC 采样</b> | RW | 0x0 |
| 1   | DMAEN | DMA 使能 (Direct memory access enable)<br>0x0: DMA 禁止<br>0x1: DMA 请求使能                                                                                                                                                | RW | 0x0 |
| 0   | ADEN  | A/D 转换使能 (ADC enable)<br>0x0: 禁用<br>0x1: 使能                                                                                                                                                                         | RW | 0x0 |

#### 14.6.3.5. ADC\_CHS

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W | Reset |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:18  | Reserved | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | -   | -     |
| 17:0   | CHxEN    | 单周期/连续扫描模式下 ADC 输入通道使能<br>0x0: 禁用<br>0x1: 使能<br>对应的通道映射:<br>CHxEN[0]: AINPAD[0] = AMP_VOUT1<br>CHxEN[1]: AINPAD[1] = AMP_VOUT2<br>CHxEN[2]: AINPAD[2] = AMP_VOUT3<br>CHxEN[3]: AINPAD[3] = PA2<br>CHxEN[4]: AINPAD[4] = PA5<br>CHxEN[5]: AINPAD[5] = PA8<br>CHxEN[6]: AINPAD[6] = PA9<br>CHxEN[7]: AINPAD[7] = PA10<br>CHxEN[8]: AINPAD[8] = PA11<br>CHxEN[9]: AINPAD[9] = PA12<br>CHxEN[10]: AINPAD[10] = PA13<br>CHxEN[11]: AINPAD[11] = PA14<br>CHxEN[12]: AINPAD[12] = PB3 | RW  | 0x0   |

|  |  |                                                                                                                                                                                                      |  |  |
|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|  |  | CHxEN[13]: AIN[0] = 选择内部 PLL_CPOUT_ADC<br>CHxEN[14]: AIN[1] = 选择内部 PMU_VPTAT<br>CHxEN[15]: AIN[2] = 选择内部 PMU_VREF_BGBUF<br>CHxEN[16]: AIN[3] = 选择内部 vdd 电压<br>CHxEN[17] : AIN[4] = 选择内部 0.5*VCCA 电压; |  |  |
|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|

#### 14.6.3.6. ADC\_IE

| Bit(s) | Name             | Description                                                                                                                                                 | R/W | Reset |
|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:22  | Reserved         | -                                                                                                                                                           | -   | -     |
| 21:16  | INTADR_SEL       | A/D 转换结束 DONE 中断入口地址选择位<br>0x0: 中断入口地址为 17 号<br>0x1: 中断入口地址为 23 号<br>Bit16: 通道 0<br>Bit17: 通道 1<br>Bit18: 通道 2<br>Bit19: 通道 3<br>Bit20: 通道 4<br>Bit21: 通道 5 | RW  | 0x0   |
| 15:14  | Reserved         | -                                                                                                                                                           | -   | -     |
| 13     | DMAFIE           | <b>DMA 全满中断使能</b>                                                                                                                                           | RW  | 0x0   |
| 12     | DMAHIE           | <b>DMA 半满中断使能</b>                                                                                                                                           | RW  | 0x0   |
| 11:7   | Reserved         | -                                                                                                                                                           | -   | -     |
| 6      | OVRIE            | overrun 中断使能                                                                                                                                                | RW  | 0x0   |
| 5:0    | TRGIE0/1/2/3/4/5 | <b>A/D 中断使能位</b><br>0x0: 禁用 A/D 中断<br>0x1: 使能 A/D 中断<br>Bit0: 通道 0<br>Bit1: 通道 1<br>Bit2: 通道 2<br>Bit3: 通道 3<br>Bit4: 通道 4<br>Bit5: 通道 5                    | RW  | 0x0   |

#### 14.6.3.7. ADC\_STA

| Bit(s) | Name       | Description                                            | R/W | Reset |
|--------|------------|--------------------------------------------------------|-----|-------|
| 31:22  | Reserved   | -                                                      | -   | -     |
| 21:15  | CHANNELSEL | <b>该 7 位显示当前数据所对应的通道</b><br>n = 通道 n 的转换数据             | 0x0 | RO    |
| 14     | BUSY       | <b>忙/空闲 (Busy)</b><br>0x0: A/D 转换器空闲<br>0x1: A/D 转换器忙碌 | 0x0 | RW    |

|      |                  |                                                                                                                                                                                                                                |     |    |
|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----|
| 13   | DMAFF            | <b>DMA 全满标志</b><br>该标志位写‘1’清零                                                                                                                                                                                                  | 0x0 | RW |
| 12   | DMAHF            | <b>DMA 半满标志</b><br>该标志位写‘1’清零                                                                                                                                                                                                  | 0x0 | RW |
| 11:6 | OVRUN0/1/2/3/4/5 | <b>通道数据覆盖标志位</b><br>0x0: ADC_DATA 数据最近一次转换结果<br>0x1: ADC_DATA 数据被覆盖<br>新的转换结果装载至寄存器之前, 若 DATA[15:0]的数据没有被读取, OVERRUN 将置‘1’<br>该标志位写‘1’清零<br>Bit6: 通道 0<br>Bit7: 通道 1<br>Bit8: 通道 2<br>Bit9: 通道 3<br>Bit10: 通道 4<br>Bit11: 通道 5 | 0x0 | RW |
| 5:0  | DONE0/1/2/3/4/5  | <b>A/D 转换结束标志位</b><br>该位由硬件在通道组转换结束时设置, 由软件清除。<br>0x0: A/D 转换未完成<br>0x1: A/D 转换完成<br>该标志位写‘1’清零<br>Bit0: 通道 0<br>Bit1: 通道 1<br>Bit2: 通道 2<br>Bit3: 通道 3<br>Bit4: 通道 4<br>Bit5: 通道 5                                            | 0x0 | RW |

Note: 当 DONE 信号清掉时, 硬件认为软件已经读走 ADC\_DATA, OVRUN 不会置 1。

#### 14.6.3.8. ADC\_DATA0

| Bit(s) | Name     | Description                                                       | R/W | Reset |
|--------|----------|-------------------------------------------------------------------|-----|-------|
| 31:16  | Reserved | —                                                                 | —   | —     |
| 15:0   | DATA0    | A/D 转换结果 (Transfer data)<br>单次采样、周期扫描、连续扫描以及<br>触发通道 0 的数据存放在该寄存器 | RW  | 0x0   |

#### 14.6.3.9. ADC\_DATA1/2/3/4/5

| Bit(s) | Name     | Description                                           | R/W | Reset |
|--------|----------|-------------------------------------------------------|-----|-------|
| 31:16  | Reserved | —                                                     | —   | —     |
| 15:0   | DATA     | A/D 转换结果 (Transfer data)<br>触发通道 1/2/3/4/5 的数据存放在该寄存器 | RW  | 0x0   |

#### 14.6.3.10. ADC\_DMAADDR

| Bit(s) | Name    | Description       | R/W | Reset |
|--------|---------|-------------------|-----|-------|
| 31:0   | DMAADDR | DMA 起始地址, byte 地址 | RW  | 0x0   |

#### 14.6.3.11. ADC\_DMACNT

| Bit(s) | Name      | Description         | R/W | Reset |
|--------|-----------|---------------------|-----|-------|
| 31:12  | Reserved  | -                   | -   | -     |
| 11:0   | dmadatcnt | 已经 DMA 完成的 ADC 数据个数 | RO  | 0x0   |

#### 14.6.3.12. ADC\_DMALEN

| Bit(s) | Name     | Description                      | R/W | Reset |
|--------|----------|----------------------------------|-----|-------|
| 31:12  | Reserved | -                                | -   | -     |
| 11:0   | dmalen   | 配置 dma buffer 长度: N=n+1 个 ADC 数据 | RW  | 0x0   |

#### 14.6.3.13. ADC\_ANACON

| Bit(s) | Name             | Description                                                                                                     | R/W | Reset |
|--------|------------------|-----------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:13  | Reserved         | -                                                                                                               | -   | -     |
| 12     | VOLTAGE_SEL      | <b>ADC 校准电源电压选择</b><br>0x0: 3.3V<br>0x1: 5V                                                                     | RW  | 0x1   |
| 11:10  | TENSEL_VDD<1:0>  | <b>测试通路选择信号</b><br>TENSEL=2' bxx<br>0x0: 选择 VCM 到 TOT<br>0x1: 选择 VREFP 到 TOT<br>0x2: 选择输入信号通路到 TOT<br>0x3: 均不选择 | RW  | 0x3   |
| 9      | CMPBSSEL_VDD     | <b>比较器偏置电流选择信号</b><br>0x0: 1X<br>0x1: 1.5X                                                                      | RW  | 0x0   |
| 8:7    | BIASSEL_VDD<1:0> | <b>内部偏置电流选择信号</b><br>BIASSEL=2' bxx<br>0x0: 1.33X<br>0x1: 1X<br>0x2: 1X<br>0x3: 0.8X                            | RW  | 0x2   |
| 6:4    | VREFSEL_VDD<2:0> | <b>内部 LDO 档位选择信号</b><br>VREFSEL_VDD<2:0>=3' bxxx                                                                | RW  | 0x0   |

|   |              |                                                          |    |     |
|---|--------------|----------------------------------------------------------|----|-----|
|   |              | 3' b000~3' b111 分别对应 1.5~4.3V, 步长为 0.4V                  |    |     |
| 3 | SELINREF_VDD | <b>选择内部 VREFP 使能信号</b><br>0x0: 选择内部 REF<br>0x1: 选择外部 REF | RW | 0x0 |
| 2 | VCMEN_VDD    | <b>内部 VCMBUFFER 模块使能信号</b><br>0x0: 关闭<br>0x1: 打开         | RW | 0x0 |
| 1 | CMPEN_VDD    | <b>比较器模块使能信号</b><br>0x0: 关闭<br>0x1: 打开                   | RW | 0x0 |
| 0 | BIASEN_VDD   | <b>偏置电流模块使能信号</b><br>0x0: 关闭<br>0x1: 打开                  | RW | 0x0 |

#### 14.6.3.14. ADC\_ANAPAR0

| Bit(s) | Name     | Description                         | R/W | Reset |
|--------|----------|-------------------------------------|-----|-------|
| 31:28  | Reserved | -                                   | -   | -     |
| 27:16  | OFFSET   | ADC 校准中的参数 Offset (有符号)<br>-(c*b)/a | RW  | 0x0   |
| 15:0   | GAIN     | ADC 校准中的参数 Gain (无符号)<br>(a/c)*2^15 | RW  | 0x0   |

Note: 校准公式  $\text{ADCDATA}/\text{GAIN} + \text{OFFSET}$ , GAIN 范围  $[2^{14}, 2^{16-1}]$

#### 14.6.3.15. ADC\_ANAPAR1

| Bit(s) | Name     | Description                                                                                                         | R/W | Reset |
|--------|----------|---------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:29  | Reserved | -                                                                                                                   | -   | -     |
| 28:16  | OFFSET0  | AINPAD[0] (AMP+ADC) 校准中的参数 Offset (有符号)<br>-(D(Vcmn)*(Gaini/Gainm - D(Vcmi)) + D(Vos)*(Gaini/Gainm)) - D(Vos)*Gaini | RW  | 0x0   |
| 15:0   | GAIN     | AMP+ADC 校准中的参数 Gain (无符号)<br>(Gainm/Gaini)*2^15                                                                     | RW  | 0x0   |

Note: 校准公式  $\text{ADCDATA}/\text{GAIN} + \text{OFFSET}$ , GAIN 范围  $[2^{14}, 2^{16-1}]$

#### 14.6.3.16. ADC\_ANAPAR2

| Bit(s) | Name     | Description                           | R/W | Reset |
|--------|----------|---------------------------------------|-----|-------|
| 31:26  | Reserved |                                       |     |       |
| 25:13  | OFFSET2  | AINPAD[2] (AMP+ADC) 校准中的参数 Offset (有) | RW  | 0x0   |

|      |         |                                                                                                                            |    |     |
|------|---------|----------------------------------------------------------------------------------------------------------------------------|----|-----|
|      |         | 符号)<br>- (D(Vcmm)*(Gaini/Gainm - D(Vcmi) +<br>D(Vos)*(Gaini/Gainm) )- D(Vos)*Gaini                                         |    |     |
| 12:0 | OFFSET1 | AINPAD[1] (AMP+ADC) 校准中的参数 Offset (有<br>符号)<br>- (D(Vcmm)*(Gaini/Gainm - D(Vcmi) +<br>D(Vos)*(Gaini/Gainm) )- D(Vos)*Gaini | RW | 0x0 |

## 15. TIMER

### 15.1. 简介

TX32M2300 系列一共包含 6 个普通 timer 和一个 watchdog。其中 timer0/1/2/3/5 为 16 位 timer，timer4 为 32 位 timer。

定时器 timer0/1/2/3/5 由一个 16 位的自动装载计数器组成，它由一个可编程的预分频器驱动。

它使用于多用途，包含测量输入信号的脉冲宽度（输入捕获），或者产生输出波形（输出比较、PWM 等）。

### 15.2. 主要特性

- 16 位递增计数器
- 可编程（可以实时修改）预分频器
- 支持选择 GPIO 作为计数时钟源
- 支持不同计数时钟源
- 允许在每次计数器周期之后更新定时周期寄存器
- 支持输入捕获功能，
  - 最多支持同时保存 4 个捕获事件指针

- 每个捕获事件极性独立可配置
- 每次捕获事件发生可配置是否复位计数值
- PWM 输出
- 支持周期和占空比 auto-reload
- 使用外部信号控制定时器和定时器互联的同步电路

## 15.3. 功能描述

### 15.3.1. 时基单元

可编程高级控制定时器的主要部分是一个 16 位计数器和与其相关的自动装载寄存器。这个计数器可以向上计数。此计数器时钟由预分频器分频得到。

计数器、自动装载寄存器和预分频器寄存器可以由软件读写，即使计数器还在运行读写仍然有效。

时基单元包括：

- 计数器寄存器 (TIMERx\_CNT)
- 周期寄存器 (TIMERx\_RD)
- 分频寄存器 (TIMERx\_CON[10:8])

自动装载寄存器是预先装载的，写或读自动重装载寄存器将访问预装载寄存器。预装载寄存器的内容在每次的更新事件（计数值等于周期值）时传送到影子寄存器，并且产生溢出事件。

在定时器模式下，计数器从 0 计数到周期值 (TIMERx\_PRD)，然后重新从 0 开始计数，并且产生一个计数器溢出中断。

分频寄存器可以将计数器的时钟频率按 2 的 n 次方分频，从而提高计数的最大周期。

### 15.3.2. 计数源选择

计数器时钟可由下列时钟源提供：

- 系统时钟
- 内部高速 RC
- 外部低速 RC
- 外部晶振
- 外部 GPIO

通过配置 TIMERx\_CTL 寄存器的 inc\_src\_sel 选择不同的计数源，配置 TIMERx\_CTL 的 psc 配置不同的分频系数。



图 15-1 Timer 的结构图

### 15.3.3. 输入捕获源

输入捕获支持外部 GPIO 触发，内部比较器触发以及外部 3 个 GPIO 异或一起作为捕获源。

输入捕获通道：



图 15-2 捕获结构图

上图中 pin 对应 GPIO 输入:

|        | CAP (Cap_sel==0x0) | XOR CAP PIN(Cap_sel==0x1) |
|--------|--------------------|---------------------------|
| TIMER0 | PA6/A10            | T0 ^ T1 ^ T2              |
| TIMER1 | PA3                | T0 ^ T1 ^ T2              |
| TIMER2 | PE0/PA9            | T0 ^ T1 ^ T2              |
| TIMER3 | PA13               | T0 ^ T1 ^ T3              |
| TIMER4 | PA0                | PA0 ^ PA1 ^ PA2           |
| TIMER5 | PA15/PA10          | T0 ^ T1 ^ T5              |

备注: T0/T1/T2/T3/T5 分别指 TIMER0/1/2/3/5 的一根 CAP PIN

cmp0 和 cmp1 分别是比较器 0/1 的比较输出信号。首先通过一个选择器选择输入触发通路后，经过同步器同步得到 CAPS，然后边沿检测器产生边沿触发信号，最后通过一个选择器选出最终捕获信号 CAPO。当捕获信号有效时，自动把当前计数器的值存入 TIMx\_CAPx 寄存器，并且产生捕获中断信号。

#### 15.3.4. 输入捕获模式

当捕获事件发生时，把当前计数值保存到对应捕获寄存器寄存器 (TNRx\_CAP1/2/3/4)。

通过配置寄存器 TIMERx\_CTL 的 cap\_num 可以配置使用 1~4 个捕获寄存器，例如使用 3 个寄存器，则第 1 次捕获事件产生，捕获值保存在 TIMERx\_CAP1，第 2 次捕获事件产生，捕获值保存在 TIMERx\_CAP2，第 3 次捕获事件产生，捕获值保存在 TIMERx\_CAP3，第 4 次捕获事件产生，捕获值保存在 TIMERx\_CAP1，依次循环。

通过配置寄存器 TIMERx\_CTL 的 capxpol 可以独立配置每个捕获事件极性，选择上升沿或者下降沿捕获。

通过配置寄存器 TIMERx\_CTL 的 ctrrst1/2/3/4 可以独立配置对应的捕获事件发生时，是否复位计数器的值。

每次捕获事件发生，都会产生对应的捕获标志 (TIMERx\_FLAG)。通过配置寄存器 TIMERx\_IE 可以独立配置每次捕获事件发生是否产生中断。

捕获模式下，支持计数值溢出中断。该模式下，计数周期固定为 16' hffff。当计数值达到 16' hffff，会产生溢出标志 ovf\_flag，通过配置 TIMERx\_IE 寄存器可以产生溢出中断。



图 15-3 结构框图 1



图 15-4 结构框图 2

### 15.3.5. PWM 模式

PWM 工作模式可以产生一个由 TIMERx\_PRD (TIMERx\_CAP1) 寄存器确定周期，TIMERx\_CMP

(TIMERx\_CAP2) 寄存器确定占空比的信号。

当使用 PWM 模式时，TIMERx\_CAP3 为 TIMERx\_CAP1 的影子寄存器，TIMERx\_CAP4 为 TIMERx\_CAP2 的影子寄存器。每次计数值 TIMER\_CNT 达到 TIMERx\_RPD 时，自动把 TIMERx\_CAP3 的值赋值到 TIMERx\_CAP1，把 TIMERx\_CAP4 的值赋值到 TIMERx\_CAP2。

写 TIMERx\_CAP1 寄存器，会自动写相同值到 TIMERx\_CAP3 寄存器。写 TIMERx\_CAP2 寄存器，会自动写相同值到 TIMERx\_CAP4 寄存器。

当计数值达到 TIMERx\_CMP 值或计数值达到 TIMERx\_PRD 值时，会产生对应标志位，如果设置了对应的中断使能位，会产生中断。可以在中断中修改 preload 寄存器(TIMERx\_CAP3/4)的值，这样下一次计数达到周期值时，就会自动加载预配置的值到周期寄存器和比较器寄存器。

提前配置好对应 PWM 输出 GPIO 对应的复用功能选择，在 TIMERx\_PRD 和 TIMERx\_CMP 寄存器中配置所需的 PWM 周期和占空比，配置 TIMx\_CTL 寄存器上的 tmr\_mode=0x2，然后启动 PWM 输出。这样，对应 IO 上就会产生期望的 PWM 波形信号，直到软件配置关闭 PWM 输出。

### 15.3.6. 触发 ADC 采样

Timer 还有一个增强型的功能，内部把 sync0 连接到 ADC 触发源，触发 ADC 采样。具体参考 ADC 章节。

### 15.3.7. timer 同步输出

输出同步信号可选择：

- 同步输入 SYNCI
- 计数值等于 TIMERx\_PRD
- 计数值等于 TIMERx\_CMP

### 15.3.8. 从模式

TIMER 定时器能够在外部模式下和一个外部的触发 SYNCI 同步：复位模式、触发模式和门控模式。

### 15.3.9. 复位模式

在发生一个触发输入事件时，计数器和它的预分频器能够重新被初始化；例如，计数器在正常运转，SYNCI 出现一个上升沿，此时计数器被清零然后从 0 重新开始计数。同时触发标志（TIMERx\_FLAG 中的）被设置，根据 TIMERx\_IE 寄存器中的 slave\_ie 的设置，产生中断。



图 15-5 复位时序

### 15.3.10. 触发模式

计数器的使能依赖于同步输入端 SYNCI 的事件。

如下例子，当 SYNCI 出现一个上升沿时，计数器开始在内部时钟驱动下计数，同时设置 slave\_flag 位，并且根据 TIMERx\_IE 寄存器中的 slave\_ie 的设置，产生中断。



图 15-6 触发时序图

### 15.3.11. 门控模式

计数器的使能依赖于输入同步信号 SYNCI 的电平。在 SYNCI 有效电平时，TIMERx\_CNT 计数，无效电平，停止计数。



图 15-7 门控时序图

### 15.3.12. DMA 传输模式

#### 15.3.12.1. DMA 产生 PWM

TIMER 支持 DMA 传输，可以用来先把 PWM 的周期和占空比提前存放到 SRAM 指定位置，然后每个周期硬件自动从 SRAM 中 load 会数据，修改 PWM 的周期和占空比，产生期望的 PWM 信号。

具体流程如下：

- 1) 提前把期望产生的 PWM 周期和占空比写到 SRAM。
- 2) 配置 TIMERx\_DADDR 和 TIMERx\_DLLEN 寄存器，配置 DMA 的起始地址和长度。
- 3) 配置 TIMERx\_DCTL 寄存器的 dma\_1pbk，配置采用循环或者单次模式。如果 dma\_1pbk=0，在执行完指定 dma 长度之后，PWM 自动停止输出。如果 dma\_1pbk=1，在执行完指定 dma 长度之后，自动从起始地址从新开始取数据，直到软件把 dma\_en 关闭，才停止。
- 4) 通过配置 TIMERx\_DCTL 寄存器的 dma\_en，使能 dma 传输模式。

### 15.3.12.2. 捕获数据通过 DMA 写到 SRAM

支持把捕获数据自动保存到 SRAM 中。

- 1) 将 TIMERx\_DCTL 清零。
- 2) 配置 TIMERx\_DADDR 和 TIMERx\_DLEN 寄存器，配置 DMA 的起始地址和长度。
- 3) 配置 TIMERx\_IE 寄存器的 dma\_f1\_ie，使能 DMA 完成中断。
- 4) 配置并启动捕获功能。
- 5) 中断之后，在 SRAM 中获取之前的捕获数据。

### 15.3.12.3. DMA 中断标志

支持 DMA buffer 半满中断和全满中断，通过 TIMERx\_IE 寄存器的 dma\_hf\_ie 和 dma\_f1\_ie 使能中断。

由于面积限制，dma 功能暂时没有添加，所以上面所说的 dma 功能没有，后续可能考虑添加到某个 timer。

### 15.3.13. 多个 timer 之间级联



图 15-8 timer 多个级联

### 15.3.14. 多个 timer 计数值同时清零

支持把所有 timer 的计数值同时清零。下面例子，把两个 TIMER 的计数值同时清零，同

步配置如下：

- 1) 配置 TIMERO\_CTL 寄存器的 syncipol = 0,
- 2) 配置 TIMERO\_CTL 寄存器的 syncosel = 2, 直接把 TIMER0 的 synci 连接到 TIMERO 的 synco。
- 3) 配置 TIMERO\_CTL 寄存器的 slave\_mode = 2, 复位模式。
- 4) 配置 TIMER1\_CTL 寄存器的 syncipol = 0。
- 5) 配置 TIMER1\_CTL 寄存器的 slave\_mode = 2, 复位模式。
- 6) 当在 synci 上产生一个有效边沿跳变, 就会同时复位 TIMER0 和 TIMER1 的计数值。

### 15.3.15. 产生带载波的 PWM 信号

一个 timer 作为后面 timer 的载波; 具体例子如下:

- 1) 把 TIMER1 配置为 PWM 输出模式 (低频);
- 2) 配置 TIMER1\_CTL 寄存器的 syncosel, 选择 PWM\_OUT 输出到 synco。
- 3) 配置 TIMER2\_CTL 寄存器的 slave\_mode = 3, 门控模式。
- 4) 配置 TIMER2 位 PWM 输出模式 (高频)。
- 5) 配置 TIMER1 和 TIMER2 使能。
- 6) 这样, 就能产生带载波的 PWM 信号。

## 15.4. 寄存器

### 15.4.1. 寄存器基址

| Name   | Base Address | Description |
|--------|--------------|-------------|
| TIMERO | 0x40001100   | TIMERO 基地址  |
| TIMER1 | 0x40001200   | TIMER1 基地址  |
| TIMER2 | 0x40001300   | TIMER2 基地址  |
| TIMER3 | 0x40001400   | TIMER3 基地址  |
| TIMER5 | 0x40001600   | TIMER5 基地址  |

## 15.4.2. 寄存器列表

| Offset Address | Name         | Description      |
|----------------|--------------|------------------|
| 0x0000         | TIMERx_CON   | 控制寄存器            |
| 0x0004         | TIMERx_EN    | 使能寄存器            |
| 0x0008         | TIMERx_IE    | 中断寄存器            |
| 0x000c         | TIMERx_FLG   | 状态寄存器            |
| 0x0010         | TIMERx_CLR   | 清除寄存器            |
| 0x0014         | TIMERx_CNT   | 计数寄存器            |
| 0x0018         | TIMERx_CAP1  | 数据寄存器 1          |
| 0x001c         | TIMERx_CAP2  | 数据寄存器 2          |
| 0x0020         | TIMERx_CAP3  | 数据寄存器 3          |
| 0x0024         | TIMERx_CAP4  | 数据寄存器 4          |
| 0x0028         | TIMER5_DCTL  | TIMER5 DMA 控制寄存器 |
| 0x002c         | TIMER5_DADDR | TIMER5 DMA 地址寄存器 |
| 0x0030         | TIMER5_DLEN  | TIMER5 DMA 长度寄存器 |
| 0x0034         | TIMER5_DCNT  | TIMER5 DMA 计数寄存器 |
| 0x0038         | TIMER_ALLCON | TIMER 总寄存器       |

## 15.4.3. 寄存器详细说明

### 15.4.3.1. TIMERx\_CON

| Bit(s) | Name     | Description                                                                                | R/W | Reset |
|--------|----------|--------------------------------------------------------------------------------------------|-----|-------|
| 31:26  | reserved | -                                                                                          | -   | -     |
| 25     | pwmpol   | <b>PWM 极性选择</b>                                                                            | RW  | 0     |
| 24     | cap4pol  | <b>capture 事件 4 的极性选择</b><br>0x0: 上升沿<br>0x1: 下降沿<br>GPIO XOR 时, 该位无效, capture 事件 4 默认边沿检测 | RW  | 0     |
| 23     | cap3pol  | <b>capture 事件 3 的极性选择</b><br>0x0: 上升沿<br>0x1: 下降沿<br>GPIO XOR 时, 该位无效, capture 事件 3 默认边沿检测 | RW  | 0     |

|       |            |                                                                                                                                                           |    |   |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|
|       |            | 沿检测                                                                                                                                                       |    |   |
| 22    | cap2pol    | <b>capture 事件 2 的极性选择</b><br>0x0: 上升沿<br>0x1: 下降沿<br>GPIO XOR 时, 该位无效, capture 事件 2 默认边沿检测                                                                | RW | 0 |
| 21    | cap1pol    | <b>capture 事件 1 的极性选择</b><br>0x0: 上升沿<br>0x1: 下降沿<br>GPIO XOR 时, 该位无效, capture 事件 1 默认边沿检测                                                                | RW | 0 |
| 20    | ctrrst4    | <b>capture 事件 4 发生时, CNT 的值自动清零</b>                                                                                                                       | RW | 0 |
| 19    | ctrrst3    | <b>capture 事件 3 发生时, CNT 的值自动清零</b>                                                                                                                       | RW | 0 |
| 18    | ctrrst2    | <b>capture 事件 2 发生时, CNT 的值自动清零</b>                                                                                                                       | RW | 0 |
| 17    | ctrrst1    | <b>capture 事件 1 发生时, CNT 的值自动清零</b>                                                                                                                       | RW | 0 |
| 16:15 | cap_cnt    | <b>捕获功能模式选择</b><br>0x0: data store in CAP1<br>0x1: data store in CAP1 CAP2<br>0x2: data store in CAP1 CAP2 CAP3<br>0x3: data store in CAP1 CAP2 CAP3 CAP4 | RW | 0 |
| 14:13 | cap_sel    | <b>捕获方式</b><br>0x0: GPIO<br>0x1: GPIO XOR<br>0x2: compare0 output<br>0x3: compare1 output                                                                 | RW | 0 |
| 12:11 | syncosel   | <b>输出同步信号选择</b><br>0x0: CNT 值=PRD 值<br>0x1: CNT 值=CMP 值<br>0x2: 把 SYNCI 值输出到 SYNC0<br>0x3: PWM 输出赋值到 SYNC0                                                | RW |   |
| 10    | syncipol   | <b>synci 极性取反</b><br>0x0: 不取反<br>0x1: 取反                                                                                                                  | RW | 0 |
| 9:8   | slave_mode | <b>synci 功能选择</b><br>0x0: disable<br>0x1: kick start<br>0x2: reset<br>0x3: gating                                                                         | RW | 0 |
| 7:5   | psc        | <b>Timer 预分频设置</b><br>0x0: 0 分频<br>0x1: 2 分频<br>0x2: 4 分频<br>0x3: 8 分频<br>0x4: 16 分频<br>0x5: 32 分频<br>0x6: 64 分频                                          | RW | 0 |

|     |             |                                                                                                                                                                                                                    |    |   |
|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|
|     |             | 0x7: 128 分频                                                                                                                                                                                                        |    |   |
| 4:2 | Inc_src_sel | <b>Timer 计数源选择</b><br>0x1: 内部低速 RC 2 分频 (32K/2)<br>0x2: 内部高速 RC 2 分频 (26M/2)<br>0x3: 外部晶振 2 分频时钟<br>0x4: timer inc pin rising<br>0x5: timer inc pin falling<br>0x6: timer inc pin rising 和 falling<br>Others: 系统时钟 | RW | 0 |
| 1:0 | Mode_sel    | <b>Timer 模式选择</b><br>0x0: timer counter mode<br>0x1: timer pwm mode<br>0x2: timer capture mode<br>Others: 保留                                                                                                       | RW | 0 |

#### 15.4.3.2. TIMERx\_EN

| Bit(s) | Name     | Description       | R/W | Reset |
|--------|----------|-------------------|-----|-------|
| 31:1   | reserved | -                 | -   | -     |
| 0      | tmren    | TIMER 使能信号, 高电平有效 | RW  | 0x0   |

#### 15.4.3.3. TIMERx\_IE

| Bit(s) | Name      | Description                                           | R/W | Reset |
|--------|-----------|-------------------------------------------------------|-----|-------|
| 31:10  | reserved  | -                                                     | -   | -     |
| 9      | dma_fl_ie | dma buffer 全满中断使能                                     | RW  | 0x0   |
| 8      | dma_hf_ie | dma buffer 半满中断使能                                     | RW  | 0x0   |
| 7      | slave_ie  | slave mode 的触发模式或者复位模式中断使能                            | RW  | 0x0   |
| 6      | cmp_ie    | CNT 值等于 CMP 值时, 中断使能,<br>仅在 pwm mode 时有效              | RW  | 0x0   |
| 5      | prd_ie    | CNT 值等于 PRD 值时, 中断使能,<br>仅在 counter mode/PWM mode 时有效 | RW  | 0x0   |
| 4      | ovf_ie    | CNT 值溢出 (16' hffff) 时, 中断使能                           | RW  | 0x0   |
| 3      | cap4_ie   | capture 事件 4 发生时, 中断使能                                | RW  | 0x0   |
| 2      | cap3_ie   | capture 事件 3 发生时, 中断使能                                | RW  | 0x0   |
| 1      | cap2_ie   | capture 事件 2 发生时, 中断使能                                | RW  | 0x0   |
| 0      | cap1_ie   | capture 事件 1 发生时, 中断使能                                | RW  | 0x0   |

#### 15.4.3.4. TIMERx\_FLG

| Bit(s) | Name       | Description     | R/W | Reset |
|--------|------------|-----------------|-----|-------|
| 31:10  | reserved   |                 | -   | -     |
| 9      | dma_fl_flg | dma buffer 全满标志 | RO  | 0x0   |

|   |            |                                                  |    |     |
|---|------------|--------------------------------------------------|----|-----|
| 8 | dma_hf_flg | dma buffer 半满标志                                  | RO | 0x0 |
| 7 | slave_flg  | slave mode 发生标志 (仅复位或触发)                         | RO | 0x0 |
| 6 | cmp_flg    | CNT 值等于 CMP 值标志,<br>仅在 pwm mode 时有效              | RO | 0x0 |
| 5 | prd_flg    | CNT 值等于 PRD 值标志,<br>仅在 counter mode/PWM mode 时有效 | RO | 0x0 |
| 4 | ovf_flg    | CNT 值溢出 (16' hffff) 标志                           | RO | 0x0 |
| 3 | cap4_flg   | capture 事件 4 发生标志                                | RO | 0x0 |
| 2 | cap3_flg   | capture 事件 3 发生标志                                | RO | 0x0 |
| 1 | cap2_flg   | capture 事件 2 发生标志                                | RO | 0x0 |
| 0 | cap1_flg   | capture 事件 1 发生标志                                | RO | 0x0 |

#### 15.4.3.5. TIMERx\_CLR

| Bit(s) | Name       | Description              | R/W | Reset |
|--------|------------|--------------------------|-----|-------|
| 31:10  | reserved   | -                        | -   | -     |
| 9      | dma_f1_clr | dma buffer 全满标志清除        | WO  | 0x0   |
| 8      | dma_hf_clr | dma buffer 半满标志清除        | WO  | 0x0   |
| 7      | slave_clr  | slave mode 发生标志清除        | WO  | 0x0   |
| 6      | cmp_clr    | CNT 值等于 CMP 值标志清除        | WO  | 0x0   |
| 5      | prd_clr    | CNT 值等于 PRD 值标志清除        | WO  | 0x0   |
| 4      | ovf_clr    | CNT 值溢出 (16' hffff) 标志清除 | WO  | 0x0   |
| 3      | cap4_clr   | capture 事件 4 发生标志清除      | WO  | 0x0   |
| 2      | cap3_clr   | capture 事件 3 发生标志清除      | WO  | 0x0   |
| 1      | cap2_clr   | capture 事件 2 发生标志清除      | WO  | 0x0   |
| 0      | cap1_clr   | capture 事件 1 发生标志清除      | WO  | 0x0   |

#### 15.4.3.6. TIMERx\_CNT

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:16  | reserved | -           | -   | -     |
| 15:0   | CNT      | 计数寄存器       | RW  | 0x0   |

#### 15.4.3.7. TIMERx\_CAP1

| Bit(s) | Name     | Description                         | R/W | Reset  |
|--------|----------|-------------------------------------|-----|--------|
| 31:16  | Reserved | -                                   | -   | -      |
| 15:0   | CAP1/PR  | 捕获模式：捕获寄存器 1<br>定时模式、PWM 模式：计数周期寄存器 | RW  | 0xFFFF |

#### 15.4.3.8. TIMERx\_CAP2

| Bit(s) | Name     | Description                       | R/W | Reset |
|--------|----------|-----------------------------------|-----|-------|
| 31:16  | Reserved |                                   | -   | -     |
| 15: 0  | CAP2/CMP | 捕获模式：捕获寄存器 2<br>定时模式、PWM 模式：比较寄存器 | RW  | 0x0   |

#### 15.4.3.9. TIMERx\_CAP3

| Bit(s) | Name       | Description                           | R/W | Reset  |
|--------|------------|---------------------------------------|-----|--------|
| 31:16  | Reserved   | -                                     | -   | -      |
| 15: 0  | CAP3/PR_SD | 捕获模式：捕获寄存器 3<br>定时模式、PWM 模式：计数周期影子寄存器 | RW  | 0xFFFF |

#### 15.4.3.10. TIMERx\_CAP4

| Bit(s) | Name        | Description                         | R/W | Reset |
|--------|-------------|-------------------------------------|-----|-------|
| 31:16  | Reserved    | -                                   | -   | -     |
| 15: 0  | CAP4/CMP_SD | 捕获模式：捕获寄存器 4<br>定时模式、PWM 模式：比较影子寄存器 | RW  | 0x0   |

#### 15.4.3.11. TIMER5\_DCTL

| Bit(s) | Name      | Description                                                                               | R/W | Reset |
|--------|-----------|-------------------------------------------------------------------------------------------|-----|-------|
| 31:2   | Reserveds |                                                                                           |     |       |
| 1      | dma_1pbk  | dma 模式选择<br>0: 单次模式，指定 dma 长度完成之后，disable<br>TIMER<br>1: 循环模式，指定 dma 长度完成之后，重新从<br>起始地址开始 | RW  | 0x0   |
| 0      | dma_en    | dma 使能                                                                                    | RW  | 0x0   |

#### 15.4.3.12. TIMER5\_DADDR

| Bit(s) | Name      | Description        | R/W | Reset |
|--------|-----------|--------------------|-----|-------|
| 31:16  | Reserved  | -                  | -   | -     |
| 15: 0  | dma_stadr | dma 起始地址 (word 对齐) | RW  | 0x0   |

#### 15.4.3.13. TIMER5\_DLEN

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|        |      |             |     |       |

|       |          |                                                 |    |     |
|-------|----------|-------------------------------------------------|----|-----|
| 31:16 | Reserved |                                                 |    |     |
| 15: 0 | dma_len  | Dma buffer 长度 (32bit) , 如果 buffer 为 n, 配置为 n-1; | RW | 0x0 |

#### 15.4.3.14. TIMER5\_DCNT

| Bit(s) | Name     | Description | R/W | Reset |
|--------|----------|-------------|-----|-------|
| 31:16  | Reserved | -           | -   | -     |
| 15: 0  | dma_cnt  | dma 数据有效个数  | RW  | 0x0   |
|        |          |             |     |       |

#### 15.4.3.15. TIMER\_ALLCON

| Bit(s) | Name      | Description  | R/W | Reset |
|--------|-----------|--------------|-----|-------|
| 31:14  | Reserved  | -            | -   | -     |
| 13     | tmr5_sync | timer5 计数值清零 | RO  | 0x0   |
| 12     | Reserved  | -            | -   | -     |
| 11     | tmr3_sync | timer3 计数值清零 | RO  | 0x0   |
| 10     | tmr2_sync | timer2 计数值清零 | RO  | 0x0   |
| 9      | tmr1_sync | timer1 计数值清零 | RO  | 0x0   |
| 8      | tmr0_sync | timer0 计数值清零 | RO  | 0x0   |
| 7:6    | reserved  | -            | -   | -     |
| 5      | tmr5_kick | timer5 启动计数  | RO  | 0x0   |
| 4      | reserved  | -            | -   | -     |
| 3      | tmr3_kick | timer3 启动计数  | RO  | 0x0   |
| 2      | tmr2_kick | timer2 启动计数  | RO  | 0x0   |
| 1      | tmr1_kick | timer1 启动计数  | RO  | 0x0   |
| 0      | tmr0_kick | timer0 启动计数  | RO  | 0x0   |

## 16. EPWM

### 16.1. 简介

EPWM 外设在许多商业及工业级电力电子系统控制中是一个关键模块。这些系统包括数字电机控制、电源开关模式控制、不间断电源 UPS 和其他形式的电源转换模块。EPWM 有时可作为 DAC 使用，占空比即为 DAC 输出的模拟量。

在 TX32M2300 中一共有 4 个 EPWM 模块，每个 EPWM 模块都支持以下功能：

1. 专用的 16 位时间控制器，可用于周期和频率的控制。
  2. 两个 PWM 输出（EPWMxA 和 EPWMxB）可进行以下配置：
    - 两个独立的 PWM 输出进行单边控制；
    - 两个独立的 PWM 输出进行双边对称控制；
    - 一个独立的 PWM 输出进行双边不对称控制；
  3. 通过软件对 PWM 信号进行异步覆盖控制。
  4. 每个 EPWM 带有 CMPA, CMPB, CMPC, CMPD 共 4 个事件触发寄存器，可用于触发 PWM 翻转和 ADC 采样。
  5. 各 EPWM 可与其他 EPWM 模块进行可编程的超前或滞后相位控制。
  6. 可在每个周期对各个 EPWM 进行硬件锁定（同步）相位关系。
  7. 具有独立的上升沿和下降沿死区延迟控制。
  8. 可编程故障区（trip zone）用于故障时的周期循环（cycle-by-cycle trip）控制和单次（one-shot trip）控制。
  9. 可通过 CPU, IO 或者比较器使 PWM 输出为强制高、低或高阻抗逻辑电平。
  10. EPWM 模块中的所有事件都可以触发 CPU 中断和启动 ADC 开始转换（ADC SOC）。
  11. 可编程事件有效降低了中断时 CPU 的负担。
- 。

## 16.2. 子模块介绍

### 16.2.1. 时基计数器子模块 (Time-base)

时基计数器子模块有如下配置选择：

1. 标定与系统时钟有关的时基计数器时钟；
2. 配置 PWM 时基计数器的频率和周期；
3. 设置时基计数器的模式：
  - 递增计数
  - 递减计数
  - 增减计数

4. 配置与另一 EPWM 模块的时基相位关系;
5. 通过软件或硬件同步不同模块之间的时基计数器;
6. 在同步事件发生后配置时基计数器的方向（递增、递减或增减计数）；
7. 指定 EPWM 模块的同步输出信号源;
  - 同步输入信号
  - 时基计数器等于 0
  - 时基计数器等于 CMPA
  - 时基计数器等于 CMPB
  - 没有输出同步信号产生

### 16.2.2. 时基计数比较器子模块 (Counter-comparator)

1. 指定 EPWMxA 和 EPWMxB 上输出的 PWM 波的占空比;
2. 指定 EPWMxA 和 EPWMxB 上开关转换的时间;
3. 产生事件触发信号，包括:
  - 时基计数器等于 0
  - 时基计数器等于周期值
  - 时基计数器等于 CMPA
  - 时基计数器等于 CMPB
  - 时基计数器等于 CMPC

### 16.2.3. 动作产生子模块 (Action-qualifier)

动作产生子模块可以将事件设置转换为各种动作类型，从而在 EPWMxA 和 EPWMxB 输出需要的波形。

1. 动作产生子模块具有以下作用：产生动作（置 1、清 0、反转）；
2. 通过软件强制控制 PWM 输出状态；

#### 16.2.4. 死区产生子模块 (Dead-band)

1. 控制开关的传统互补死区关系;
2. 指定输出上升沿延时值;
3. 指定输出下降沿延时值;
4. 忽略死区模块, 这种情况下 PWM 波形无任何变化地通过;



图 16-1 死区结构框图

#### 16.2.5. 事件触发子模块 (Event-trigger)

事件触发子模块主要功能如下:

1. 接收由时基计数器或时基计数比较器子模块产生的事件输入;
2. 通过时基计数器方向限定事件 up/down;
3. 在下列情况下使用计数逻辑产生中断请求和启动 adc 转换:
  - 每次事件
  - 每两次事件
  - 每三次事件
4. 通过事件计数器和标志提供事件产生的可视化;
5. 允许软件强制产生中断和启动 ADC 转换;
6. 当事件产生时事件触发子模块管理时基子模块的事件的产生和计数比较子模块产

生 CPU 中断，产生 ADC 开始转换的脉冲；

### 16.2.6. 故障区子模块 (Trip-zone)

Trip-Zone 子模块的主要功能如下：

1. 故障区输入信号 TZ1 到 TZ6 可以灵活地映射到任何一个 EPWM 模块；
2. 根据故障情况，EPWMxA 和 EPWMxB 输出可以被强制输出为下列信号：
  - 强制输出高电平
  - 强制输出低电平
  - 强制输出高阻抗
  - 没有动作发生
3. 支持在短路或过流情况下的单次 trip；
4. 支持周期循环 (CBC) 限流操作；
5. 每个 Trip-zone 输入引脚都可以被分派为单次或周期循环的操作；
6. 在任何一个 Trip-zone 引脚上都有可能发生中断；
7. 支持软件强制 trip；
8. 如果不需要，可以忽略 Trip-zone 子模块；

### 16.3. 功能描述及常用拓扑

EPWM 间的同步功能和主要配置选项如下：

1. 选择同步 (Syncin) 信号源；
2. 使能同步选通脉冲开关，出现同步脉冲时会将相位寄存器中的数值加载进计数器；
3. 也可不做任何操作，关掉同步选通脉冲开关；
4. SyncOut 的连接选择：
  - Sync flow-through —— 将 SyncOut 直接与 SyncIn 相连；
  - Master 模式下，在 PWM 边界提供一个 sync 信号——SyncOut 与 CTR == 0 连接；
  - Master 模式下，在任意可编程时间点下提供一个 sync 信号——SyncOut 与 CTR == CMPA 相连或者 CTR == CMPP 相连；
  - 模块是单独一个模式并且和其他模块不同步时——SyncOut 与 X 相连（不使能）；

最常见的两种——Master 模式和 Slave 模式——如下图所示：



图 16-2 同步示意图

### 16.3.1. 独立频率控制多个 Buck 转换电路

最简单的功率变换电路拓扑之一是 buck。将一个 EPWM 模块配置为 master 时，可以用一个频率控制两个 buck 级。如果要求每个 buck 电路用独立频率控制，那么每个 converter 级都需要分配一个 EPWM 模块。下图显示了 4 个 buck 级及波形，每个都工作在独立频率上。在这种情况下，所有的四个 EPWM 模块则都被配置为 Master 并且均不同步。注意即使有四个 buck 级，但是一共只有三种波形。



图 16-3 控制示意图



图 16-4 时序示意图

### 16.3.2. 相同频率控制多个 Buck 转换电路

如果要求两个 Buck 电路同步，那么 EPWM2 可以被配置为 slave 并且工作在 EPWM1 的整数倍频率下。从 master 到 slave 的 sync 信号可以确保这些模块保持锁定。下图显示的就是这种设置下的模型及波形。



图 16-5 控制示意图 2



图 16-6 时序示意图 2

### 16.3.3. 控制多个 H 半桥电路 (HHB) 转换电路

控制多个开关元件的拓扑也可以用相同的 EPWM 模块处理。用一个 EPWM 模块控制一个 H 半桥级电路是有可能的。这种控制的方法还可以被扩充至多级 H 半桥级电路。下图显示在控制两个同步的 H 半桥级电路时，可以使第二级电路工作在第一级电路的工作频率的整数倍下。及这种设置下产生的波形。

Slave 被配置为 Sync flow-through。如果需要，可以增加第三个 H 半桥由第三个 EPWM 模块控制，并且必须与 master 同步。



图 16-7 控制示意图 3



图 16-8 时序示意图 3

#### 16.3.4. 控制电机的双三相逆变器（ACI 和 PMSM）

多模块控制单个功率级的思想可以扩充至三相逆变器中。在这种情况下，6个开关元件可以由三个 PWM 模块控制，每支路一个。每条支路都必须在相同的频率下开关并且所有的支路都要同步。所以，1个 master+2个 slave 的组合可以轻松地解决这样的需求。下图显示了6个 PWM 模块是如何控制2个独立的三相逆变器的，每一个模块都运行着一个电机。接着的图是其运行波形。

如前几节所示，我们可以让每个逆变器都工作在不同的频率下（例如图 3-9 的例子中模块 1 和 4 都作为 master）；或者设置 1 个为 master、5 个为 slave，使两个逆变器同步。在这种情况下，模块 4、5、6（三个模块的频率相等）的频率是模块 1、2、3（三个模块的频率相等）的频率的整数倍。



图 16-9 控制示意图 4



图 16-10 时序示意图 4

### 16.3.5. PWM 模块间相位控制的实际应用

直到目前为止，没有一种例子使用了相位寄存器（TBPHS）。相位寄存器不是被设置为 0 就是被完全忽略该值。然而，通过给 TBPHS 寄存器配置适当的值，多个 PWM 模块可以处理其他的功率拓扑级，这些拓扑级依靠各支路间的相位关系可以进行正确的操作。一个 PWM 模块可以配置 SyncIn 脉冲使得 TBPHS 寄存器可以加载进 TBCTR 寄存器。如上述观点所示，下图显示了一个相位关系为  $120^\circ$  的 master 和 slave。



图 16-11 控制示意图 5

下图显示了这个配置下产生的时序波形图。Master 和 slave 的 TBPRD 都等于 600。Slave 的 TBPHS = 200 ( $200/600 \times 360^\circ = 120^\circ$ )。当 master 产生 SyncIn 脉冲时，TBPHS = 200 的值就会被加载进 slave 的 TBCTR 寄存器。所以 slave 的时基总是超前于 master 的时基  $120^\circ$ 。



图 16-12 时序示意图 5

### 16.3.6. 控制三相交错 DC/DC 交换电路

如下图，通用的功率拓扑是利用了模块之间的相位偏移。该系统使用了 3 个 PWM 模块，其中模块 1 被配置为 master。工作时，相邻的模块之间的相位关系为  $F = 120^\circ$ 。这是通过分别设置 slave 的 TBPHS 寄存器 2 和 TBPHS 寄存器 3 的值为周期的  $1/3$  和  $2/3$  来实现的。例如，如果周期寄存器被载入一个 900 计数的值，那么  $TBPHS(\text{slave}2) = 300$  并且  $TBPHS(\text{slave}3) = 600$ 。所有的 slave 模块都要与 master1 模块同步。

这个思想通过适当设置 TBPHS 寄存器的值可以扩充 4 个甚至更多的相位。下列公式提供了 TBPHS 寄存器 N 个相位值：

$$TBPHS(N, M) = (\text{TBPRD}/N) * (-1)$$

其中，N 为相位值的个数

M 为 PWM 模块的个数

例如，在 3 个相位值的情况下， $\text{TBPRD} = 900$ ，

$$TBPHS(3, 2) = (900/3) * (2-1) = 300 \text{ (这是 slave 模块 2 的相位值)};$$

$$TBPHS(3, 3) = (600) \text{ (这是 slave 模块 3 的相位值)}.$$



图 16-13 控制示意图 6



图 16-14 时序示意图 6

### 16.3.7. 控制 0 电压转换的全桥转换电路 (ZVSFB)

下图假设了一种在各模块之间静态的或恒定不变的相位关系。在这种情况下，可以通过调制占空比来实现控制。也有可能在循环的基础中动态地改变相位值。这个特性使得模块本身可以像相移全桥或 0 电压转换全桥一样控制功率级拓扑。在这里控制的参数不是占空比（占空比保持不变或保持大约为 50%），而是支路之间的相位关系。通过两个 PWM 模块的资源配置控制单功率级，就可以实现这样的一个系统，这就要求控制 4 个开关元件。下图显示一个同步的 master/slave 组合共同控制一个 H 全桥。在这种情况下，master 和 slave 都被要求在相同的 PWM 频率下进行转换。可以通过 slave 的相位寄存器 (TBPHS) 来控制相位。不使用 master 的相位寄存器，因此 master 的相位寄存器应初始化为 0。



图 16-15 控制示意图 7



图 16-16 时序示意图 7

### 16.3.8. 控制峰值电流模式（Peak Current Mode）控制 Buck 模块

峰值电流模式控制技术提供了自动过流限流、输入电压变化的快速校正以及还原磁饱和

等优点。下图显示了 EPWM1A 和片上比较器在 Buck 变换器拓扑上的应用。输出电流可以通过电流感应电阻感应并转到片上比较器的正极。内部可编程 8 位 DAC 提供一个参考峰值电流给比较器的正极。作为选择，一个外部参考电流也连到该输入端。比较器的输出是数字比较器子模块的输入。EPWM 模块这么配置，是为了当感应电流达到峰值参考电流时立即触发 EPWM 的输出。采用了一种周期循环的机制。并显示了这种配置下产生的波形。



图 16-17 控制示意图 8



图 16-18 时序示意图 8

### 16.3.9. 控制 H 桥 LLC 谐振变换器

多年来，多种谐振变换器的拓扑在电力电子领域都很有名。另外，近来在要求高效和高功率密度的消费级电子应用方面，H 桥 LLC 谐振变换器拓扑十分受欢迎。例如，EPWM1 的单通道配置十分详细，但其配置可以简单扩充为多通道。控制参数是频率而不是占空比（占空

比应保持不变或保持在大约 50%）。用户需要实时更新死区时间，通过调整足够的软交换时延来提高效率。



图 16-19 控制示意图 9



图 16-20 控制示意图 9

## 16.4. 寄存器

### 16.4.1. 寄存器地址

| Name | Base Address | Description |
|------|--------------|-------------|
| EPWM | 0x40001800   | EPWM 基地址    |

## 16.4.2. 寄存器列表

| Offset Address | Name              | Description |
|----------------|-------------------|-------------|
| 0x0000         | EPWMx_TBCTL       | TB 控制寄存器    |
| 0x0004         | EPWMx_TBPRD       | TB 周期寄存器    |
| 0x0008         | EPWMx_TBPHASE     | TB 相位寄存器    |
| 0x000c         | EPWMx_CMPCTL      | CMP 控制寄存器   |
| 0x0010         | EPWMx_CMPA        | CMPA 寄存器    |
| 0x0014         | EPWMx_CMPB        | CMPB 寄存器    |
| 0x0018         | EPWMx_CMPC        | CMPC 寄存器    |
| 0x001c         | EPWMx_CMPD        | CMPD 寄存器    |
| 0x0020         | EPWMx_AQCTLAB     | AQ 控制寄存器    |
| 0x0024         | EPWMx_AQSFRC      | AQ 行为寄存器 0  |
| 0x0028         | EPWMx_AQCSFRC     | AQ 行为寄存器 1  |
| 0x002c         | EPWMx_DBCTL       | DB 控制寄存器    |
| 0x0030         | EPWMx_DEDELAY     | DB 延迟寄存器    |
| 0x0034         | EPWMx_ETCTL       | ET 控制寄存器    |
| 0x0038         | EPWMx_ETCTL2      | ET 控制寄存器 2  |
| 0x003c         | EPWMx_ETFAG       | ET 状态寄存器    |
| 0x0040         | EPWMx_DCCTL       | DC 控制寄存器    |
| 0x0044         | EPWMx_DCTRIPSEL   | DC 触发寄存器    |
| 0x0048         | EPWMx_BLANKOFFSET | DC 窗口寄存器    |
| 0x004c         | EPWMx_WINDIDTH    | DC 窗口长度寄存器  |
| 0x0050         | EPWMx_TZCTL       | TZ 控制寄存器    |
| 0x0054         | EPWMx_TZFLAG      | TZ 状态寄存器    |
| 0x0058         | EPWMx_DCCAP       | DC 捕获寄存器    |
| 0x005c         | EPWM_TTCTL        | 总控制寄存器      |

### 16.4.3. 寄存器详细说明

#### 16.4.3.1. EPWMx\_TBCTL

| Bit(s) | Name      | Description                                                                                                                                                            | R/W | Reset |
|--------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | TBCTR     | 读取该寄存器可以知道此时计数器的计数值                                                                                                                                                    | R   | 0x0   |
| 15:13  | CLK_DIV   | 模块时钟分频<br>0x0: epwm clk<br>0x1: epwm clk div 2<br>0x2: epwm clk div 4<br>0x3: epwm clk div 8<br>0x4: epwm clk div 16                                                   | RW  | 0x0   |
| 12:10  | Reserved  | -                                                                                                                                                                      | -   | -     |
| 9      | TBCTR_DIR | TB 计数方向状态位<br>0x0: TB 处于递减<br>0x1: TB 处于递增                                                                                                                             | R   | 0x0   |
| 8      | SYNCI     | 输入同步锁存状态位<br><b>读:</b><br>0x0: 没有发生外部同步事件。<br>0x1: 发生了外部同步事件(EPWMx_SYNCI)<br><b>写:</b><br>0x0: 无效:<br>0x1: 在此位上写入 1 将清除闩锁事件。                                           | RW  | 0x0   |
| 7:5    | SYNCO_SEL | 同步信号输出选择<br>0x0: sync in<br>0x1: tbcnt equal zero<br>0x2: tbcnt equal cmpa<br>0x3: tbcnt equal cmpb<br>0x4: tbcnt equal cmpc<br>0x5: tbcnt equal cmpd<br>0x6 ~ 0x7: 无效 | RW  | 0x0   |
| 4      | SWF_SYNC  | 软件同步使能<br>0x0: 关闭<br>0x1: 打开                                                                                                                                           | W   | 0x0   |
| 3      | PHSEN     | 相位同步使能<br>0x0: 关闭<br>0x1: 打开                                                                                                                                           | RW  | 0x0   |
| 2:1    | CTRMODE   | 计数模式选择<br>0x0: Up mode<br>0x1: Down mode<br>0x2: Up Down mode<br>0x3: constant                                                                                         | RW  | 0x0   |
| 0      | PRDLD     | 周期寄存器的影子寄存器使能<br>0x0: 当计数器 TBCTR 等于零时, 周期寄存器 (TBPRD) 从阴影寄存器加载                                                                                                          | RW  | 0x0   |

|  |  |                              |  |  |
|--|--|------------------------------|--|--|
|  |  | 0x1：立即加载 TBPRD 寄存器，而不使用阴影寄存器 |  |  |
|--|--|------------------------------|--|--|

#### 16.4.3.2. EPWMx\_TBPRD

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                               | R/W | Reset |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | reserved | -                                                                                                                                                                                                                                                                                         | -   | -     |
| 15:0   | TBPRD    | <p><b>TB 计数器的周期配置</b><br/>           该寄存器的阴影由 TBCTL[PRDL0]位启用和禁用。默认情况下，这个寄存器是隐藏的。</p> <ul style="list-style-type: none"> <li>如果 TBCTL[PRDL0] = 0，则启用影子寄存器，任何写入或读取将自动到影子寄存器。在这种情况下，当 TB 计数器等于零时，寄存器将从影子寄存器加载；</li> <li>如果 TBCTL[PRDL0] = 1，那么阴影被禁用，任何写或读都将直接到计数寄存器，即主动控制硬件的寄存器；</li> </ul> | RW  | 0x0   |

#### 16.4.3.3. EPWMx\_TBPHASE

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                        | R/W | Reset |
|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:17  | reserved | -                                                                                                                                                                                                                                                                                                  | -   | -     |
| 16     | TBDIR    | <p><b>设置计数器的计数方向</b><br/>           设置所选 ePWM 相对于提供同步输入信号的时基的时基计数器方向</p> <ul style="list-style-type: none"> <li>如果 TBCTL[PHSEN] = 0，则同步事件将被忽略，并且没有加载该方向的时基方向；</li> <li>如果 TBCTL[PHSEN] = 1，则当同步事件发生时，时基方向将被加载方向(TBDIR)；同步事件可以由输入同步信号(EPWMxSYNCl)发起，也可以由软件强制同步。<br/> <b>注意：</b>此位仅用于上下模式</li> </ul> | RW  | 0x0   |
| 15:0   | TBPHS    | <p><b>同步信号触发时，进行同步的相位值</b><br/>           这些位设置所选 ePWM 相对于提供同步输入信号的时基的时基计数器相位。</p> <ul style="list-style-type: none"> <li>如果 TBCTL[PHSEN] = 0，则同步事件将被忽略，并且不加载时序计数器；</li> <li>如果 TBCTL[PHSEN] = 1，则当同步事件发生时，时基计数器(TBCTR)将加载相位(TBPHS)；同步事件可以由输入同步信号(EPWMxSYNCl)发起，也可以由软件强制同步。</li> </ul>             | RW  | 0x0   |

#### 16.4.3.4. EPWMx\_CMPCTL

| Bit(s) | Name      | Description                                                                                                                                     | R/W | Reset |
|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | reserved  | -                                                                                                                                               | -   | -     |
| 15     | SHDWFULL  | <b>CMPD 影子寄存器状态</b><br>0x0: 影子寄存器未满<br>0x1: 影子寄存器处于满的状态, 如果 CPU 再写会覆盖到                                                                          | RO  | 0x0   |
| 14     | SHDWDMODE | <b>CMPD 加载模式选择</b><br>0x0: 阴影模式, 作为双缓冲。所有通过 CPU 的写操作都要访问影子寄存器<br>0x1: 立即模式, 只使用活动比较寄存器。所有写和读操作都直接访问活动寄存器, 以便立即进行比较操作                            | RW  | 0x0   |
| 13:12  | LOADDMODE | <b>CMPD 加载数据时刻点选择</b><br>该功能只在影子模式下有效<br>0x0: 在 CTR=0 时, 加载比较值数据<br>0x1: 在 CTR=PRD 时, 加载比较值数据<br>0x2: 加载 CTR=0 和 CTR=PRD 时, 都加载比较值数据<br>0x3: 无效 | RW  | 0x0   |
| 11     | SHDWCFULL | <b>CMPC 影子寄存器状态</b><br>0x0: 影子寄存器未满<br>0x1: 影子寄存器处于满的状态, 如果 CPU 再写会覆盖到                                                                          | RO  | 0x0   |
| 10     | SHDWCMODE | <b>CMPC 加载模式选择</b><br>0x0: 阴影模式, 作为双缓冲。所有通过 CPU 的写操作都要访问影子寄存器<br>0x1: 立即模式, 只使用活动比较寄存器。所有写和读操作都直接访问活动寄存器, 以便立即进行比较操作                            | RW  | 0x0   |
| 9:8    | LOADCMODE | <b>CMPC 加载数据时刻点选择</b><br>该功能只在影子模式下有效<br>0x0: 在 CTR=0 时, 加载比较值数据<br>0x1: 在 CTR=PRD 时, 加载比较值数据<br>0x2: 加载 CTR=0 和 CTR=PRD 时, 都加载比较值数据<br>0x3: 无效 | RW  | 0x0   |
| 7      | SHDWBFULL | <b>CMPB 影子寄存器状态</b><br>0x0: 影子寄存器未满<br>0x1: 影子寄存器处于满的状态, 如果 CPU 再写会覆盖到                                                                          | RO  | 0x0   |
| 6      | SHDWAFULL | <b>CMPA 影子寄存器状态</b><br>0x0: 影子寄存器未满                                                                                                             | RO  | 0x0   |

|     |           |                                                                                                                                                 |    |     |
|-----|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |           | 0x1: 影子寄存器处于满的状态, 如果 CPU 再写会覆盖到                                                                                                                 |    |     |
| 5   | SHDWBMODE | <b>CMPB 加载模式选择</b><br>0x0: 阴影模式, 作为双缓冲。所有通过 CPU 的写操作都要访问影子寄存器<br>0x1: 立即模式, 只使用活动比较寄存器。所有写和读操作都直接访问活动寄存器, 以便立即进行比较操作                            | RW | 0x0 |
| 4   | SHDWAMODE | <b>CMPA 加载模式选择</b><br>0x0: 阴影模式, 作为双缓冲。所有通过 CPU 的写操作都要访问影子寄存器<br>0x1: 立即模式, 只使用活动比较寄存器。所有写和读操作都直接访问活动寄存器, 以便立即进行比较操作                            | RW | 0x0 |
| 3:2 | LOADBMODE | <b>CMPB 加载数据时刻点选择</b><br>该功能只在影子模式下有效<br>0x0: 在 CTR=0 时, 加载比较值数据<br>0x1: 在 CTR=PRD 时, 加载比较值数据<br>0x2: 加载 CTR=0 和 CTR=PRD 时, 都加载比较值数据<br>0x3: 无效 | RW | 0x0 |
| 1:0 | LOADAMODE | <b>CMPA 加载数据时刻点选择</b><br>该功能只在影子模式下有效<br>0x0: 在 CTR=0 时, 加载比较值数据<br>0x1: 在 CTR=PRD 时, 加载比较值数据<br>0x2: 加载 CTR=0 和 CTR=PRD 时, 都加载比较值数据<br>0x3: 无效 | RW | 0x0 |

#### 16.4.3.5. EPWMx\_CMPA

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                              | R/W | Reset |
|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | reserved | -                                                                                                                                                                                                                                                                                                                                                        | -   | -     |
| 15:0   | CMPA     | <b>CMPA 寄存器值</b><br>默认情况下, 对该寄存器的写入是隐藏的。通过 CMPCTL[SHDWAMODE]位启用和禁用阴影。 <ul style="list-style-type: none"> <li>● 如果 CMPCTL[SHDWAMODE]=0, 则启用阴影, 任何写入都将自动到阴影寄存器。CMPCTL[LOADAMODE]位字段决定哪个事件将从影子寄存器加载活动寄存器。</li> <li>● 在写入之前, 可以读取 CMPCTL[shdwfull1]位, 以确定阴影寄存器当前是否已满。</li> <li>● 如果 CMPCTL[SHDWAMODE]=1, 那么影子寄存器被禁用, 任何写入都将直接到活动寄存器, 即主动控制硬件的寄存器。</li> </ul> | RW  | 0x0   |

#### 16.4.3.6. EPWMx\_CMPB

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                  | R/W | Reset |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | reserved | -                                                                                                                                                                                                                                                                                                                                                            | -   | -     |
| 15:0   | CMPB     | <p><b>CMPB 寄存器值</b></p> <p>默认情况下，对该寄存器的写入是隐藏的。通过 CMPCTL[SHDWAMODE]位启用和禁用阴影。</p> <ul style="list-style-type: none"> <li>● 如果 CMPCTL[SHDWAMODE]=0，则启用阴影，任何写入都将自动到阴影寄存器。CMPCTL[LOADAMODE]位字段决定哪个事件将从影子寄存器加载活动寄存器。</li> <li>● 在写入之前，可以读取 CMPCTL[shdwfull11]位，以确定阴影寄存器当前是否已满。</li> <li>● 如果 CMPCTL[SHDWAMODE]=1，那么影子寄存器被禁用，任何写入都将直接到活动寄存器，即主动控制硬件的寄存器。</li> </ul> | RW  | 0x0   |

#### 16.4.3.7. EPWMx\_CMPC

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                  | R/W | Reset |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | reserved | -                                                                                                                                                                                                                                                                                                                                                            | -   | -     |
| 15:0   | CMPC     | <p><b>CMPC 寄存器值</b></p> <p>默认情况下，对该寄存器的写入是隐藏的。通过 CMPCTL[SHDWAMODE]位启用和禁用阴影。</p> <ul style="list-style-type: none"> <li>● 如果 CMPCTL[SHDWAMODE]=0，则启用阴影，任何写入都将自动到阴影寄存器。CMPCTL[LOADAMODE]位字段决定哪个事件将从影子寄存器加载活动寄存器。</li> <li>● 在写入之前，可以读取 CMPCTL[shdwfull11]位，以确定阴影寄存器当前是否已满。</li> <li>● 如果 CMPCTL[SHDWAMODE]=1，那么影子寄存器被禁用，任何写入都将直接到活动寄存器，即主动控制硬件的寄存器。</li> </ul> | RW  | 0x0   |

#### 16.4.3.8. EPWMx\_CMPD

| Bit(s) | Name     | Description                                                                                                                                                       | R/W | Reset |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | reserved | -                                                                                                                                                                 | -   | -     |
| 15:0   | CMPD     | <p><b>CMPD 寄存器值</b></p> <p>默认情况下，对该寄存器的写入是隐藏的。通过 CMPCTL[SHDWAMODE]位启用和禁用阴影。</p> <ul style="list-style-type: none"> <li>● 如果 CMPCTL[SHDWAMODE]=0，则启用阴影，</li> </ul> | RW  | 0x0   |

|  |  |                                                                                                                                                                                                                                         |  |  |
|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|  |  | <p>任何写入都将自动到阴影寄存器。 CMPCTL[LOADAMODE]位字段决定哪个事件将从影子寄存器加载活动寄存器。</p> <ul style="list-style-type: none"> <li>在写入之前,可以读取 CMPCTL[shdwfull1]位,以确定阴影寄存器当前是否已满。</li> <li>如果 CMPCTL[SHDWAMODE]=1,那么影子寄存器被禁用,任何写入都将直接到活动寄存器,即主动控制硬件的寄存器。</li> </ul> |  |  |
|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|

#### 16.4.3.9. EPWMx\_AQCTLAB

| Bit(s) | Name     | Description                                                                                                                         | R/W | Reset |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:28  | reserved | -                                                                                                                                   | -   | -     |
| 27:26  | CBDB     | <p>计数器 CNT 处于递减趋势下,当 CNT=CMPB 时 EPWMxB 的行为控制</p> <p>0x0: 保持原来<br/>0x1: EPWMxB 输出低电平<br/>0x2: EPWMxB 输出高电平<br/>0x3: 翻转</p>           | RW  | 0x0   |
| 25:24  | CBUB     | <p>计数器 CNT 处于递增趋势下,当 CNT=CMPB 时 EPWMxB 的行为控制</p> <p>0x0: 保持原来<br/>0x1: EPWMxB 输出低电平<br/>0x2: EPWMxB 输出高电平<br/>0x3: 翻转</p>           | RW  | 0x0   |
| 23:22  | CADB     | <p>计数器 CNT 处于递减趋势下,当 CNT=CMPA 时 EPWMxB 的行为控制</p> <p>0x0: 保持原来<br/>0x1: EPWMxB 输出低电平<br/>0x2: EPWMxB 输出高电平<br/>0x3: 翻转</p>           | RW  | 0x0   |
| 21:20  | CAUB     | <p>计数器 CNT 处于递增趋势下,当 CNT=CMPA 时 EPWMxB 的行为控制</p> <p>0x0: 保持原来<br/>0x1: EPWMxB 输出低电平<br/>0x2: EPWMxB 输出高电平<br/>0x3: 翻转</p>           | RW  | 0x0   |
| 19:18  | PRDB     | <p>计数器 CNT 处于 up and down 模式下,当 CNT=PRD 时 EPWMxB 的行为控制</p> <p>0x0: 保持原来<br/>0x1: EPWMxB 输出低电平<br/>0x2: EPWMxB 输出高电平<br/>0x3: 翻转</p> | RW  | 0x0   |
| 17:16  | ZROB     | 计数器 CNT 处于 up and down 模式下,当 CNT=0 时 EPWMxB 的行为控制                                                                                   | RW  | 0x0   |

|       |          |                                                                                                                                  |    |     |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------|----|-----|
|       |          | 0x0: 保持原来<br>0x1: EPWMxB 输出低电平<br>0x2: EPWMxB 输出高电平<br>0x3: 翻转                                                                   |    |     |
| 15:12 | reserved | -                                                                                                                                | -  | -   |
| 11:10 | CBDA     | 计数器 CNT 处于递减趋势下, 当 CNT=CMPB 时<br><b>EPWMxA 的行为控制</b><br>0x0: 保持原来<br>0x1: EPWMxA 输出低电平<br>0x2: EPWMxA 输出高电平<br>0x3: 翻转           | RW | 0x0 |
| 9:8   | CBUA     | 计数器 CNT 处于递增趋势下, 当 CNT=CMPB 时<br><b>EPWMxA 的行为控制</b><br>0x0: 保持原来<br>0x1: EPWMxA 输出低电平<br>0x2: EPWMxA 输出高电平<br>0x3: 翻转           | RW | 0x0 |
| 7:6   | CADA     | 计数器 CNT 处于递减趋势下, 当 CNT=CMPA 时<br><b>EPWMxA 的行为控制</b><br>0x0: 保持原来<br>0x1: EPWMxA 输出低电平<br>0x2: EPWMxA 输出高电平<br>0x3: 翻转           | RW | 0x0 |
| 5:4   | CAUA     | 计数器 CNT 处于递增趋势下, 当 CNT=CMPA 时<br><b>EPWMxA 的行为控制</b><br>0x0: 保持原来<br>0x1: EPWMxA 输出低电平<br>0x2: EPWMxA 输出高电平<br>0x3: 翻转           | RW | 0x0 |
| 3:2   | PRDA     | 计数器 CNT 处于 up and down 模式下, 当 CNT=PRD 时<br><b>EPWMxA 的行为控制</b><br>0x0: 保持原来<br>0x1: EPWMxA 输出低电平<br>0x2: EPWMxA 输出高电平<br>0x3: 翻转 | RW | 0x0 |
| 1:0   | ZROA     | 计数器 CNT 处于 up and down 模式下, 当 CNT=0 时<br><b>EPWMxA 的行为控制</b><br>0x0: 保持原来<br>0x1: EPWMxA 输出低电平<br>0x2: EPWMxA 输出高电平<br>0x3: 翻转   | RW | 0x0 |

#### 16.4.3.10. EPWMX\_AQSFRC

| Bit(s) | Name | Description | R/W | Reset |
|--------|------|-------------|-----|-------|
|--------|------|-------------|-----|-------|

|      |          |                                                                                                       |    |     |
|------|----------|-------------------------------------------------------------------------------------------------------|----|-----|
| 31:8 | reserved | -                                                                                                     | -  | -   |
| 7:6  | RLDCSF   | <b>AQCSFRC 影子寄存器加载状态</b><br>0x0: CNT=0<br>0x1: CNT=PRD<br>0x2: CNT=0 或者 CNT=PRD<br>0x3: 立即加载          | R  | 0x0 |
| 5    | OTSFB    | <b>软件触发 One-Time, 让 EPWMxB 响应行为</b><br>0x0: 无效<br>0x1: 立即触发一次 One-Time, EPWMxB 做出相对应的行为               | RW | 0x0 |
| 4:3  | ACTSFB   | <b>触发 One-Time 信号后, EWPMxB 行为选择</b><br>0x0: 保持原来<br>0x1: EPWMxA 输出低电平<br>0x2: EPWMxA 输出高电平<br>0x3: 翻转 | RW | 0x0 |
| 2    | OTSFA    | <b>软件触发 One-Time, 让 EPWMxA 响应行为</b><br>0x0: 无效<br>0x1: 立即触发一次 One-Time, EPWMxA 做出相对应的行为               | RW | 0x0 |
| 1:0  | ACTSFA   | <b>触发 One-Time 信号后, EWPMxA 行为选择</b><br>0x0: 保持原来<br>0x1: EPWMxA 输出低电平<br>0x2: EPWMxA 输出高电平<br>0x3: 翻转 | RW | 0x0 |

#### 16.4.3.11. EPWMX\_AQCSFRC

| Bit(s) | Name     | Description                                                                                                                                                         | R/W | Reset |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:4   | reserved | -                                                                                                                                                                   | -   | -     |
| 3:2    | CSFB     | <b>软件循环触发配置 (EPWMxB)</b><br>立即模式下, 连续触发会在下一个 TBCLK 边沿生效;<br>影子模式下, 要在影子寄存器加载后的下一个 TBCLK 边沿才会生效。<br>0x0: 保持原来<br>0x1: EPWMxA 输出低电平<br>0x2: EPWMxA 输出高电平<br>0x3: 保持原来 | RW  | 0x0   |
| 1:0    | CSFA     | <b>软件循环触发配置 (EPWMxA)</b><br>立即模式下, 连续触发会在下一个 TBCLK 边沿生效;<br>影子模式下, 要在影子寄存器加载后的下一个 TBCLK 边沿才会生效。<br>0x0: 保持原来<br>0x1: EPWMxA 输出低电平                                   | RW  | 0x0   |

|  |  |                                |  |  |
|--|--|--------------------------------|--|--|
|  |  | 0x2: EPWMxA 输出高电平<br>0x3: 保持原来 |  |  |
|--|--|--------------------------------|--|--|

#### 16.4.3.12. EPWMX\_DBCTL

| Bit(s) | Name          | Description                                                                                                                                                                                            | R/W | Reset |
|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:19  | reserved      | -                                                                                                                                                                                                      | -   | -     |
| 18     | SHDWDBCTLMODE | <b>DBCTL加载模式</b><br>0x0: 立即模式<br>0x1: 影子模式                                                                                                                                                             | RW  | 0x0   |
| 17:16  | LOADDBCTLMODE | <b>DBCTL加载点选择</b><br>0x0: CNT = 0<br>0x1: CNT = PRD<br>0x2: CNT = 0, 或者CNT= PRD<br>0x3: 无效<br>注意: 只在影子模式有效                                                                                             | RW  | 0x0   |
| 15     | HALFCYCLE     | <b>死区时钟分频选择</b><br>0x0: 不分频<br>0x1: 1/2 EPWM 时钟                                                                                                                                                        | RW  | 0x0   |
| 14     | reserved      | -                                                                                                                                                                                                      | -   | -     |
| 13:12  | OUTSWAP       | <b>死区输出交换设置</b><br>在图16-1中, BIT13对应S7, BIT12对应这个S6<br>0x0: OutA = A-path, OutB = B-path<br>0x1: OutA = A-path, OutB = A-path<br>0x2: OutA = B-path, OutB = B-path<br>0x3: OutA = B-path, OutB = A-path | R/W | 0x0   |
| 11     | SHDWDBFEDMODE | <b>FED死区加载模式</b><br>0x0: 立即模式<br>0x1: 影子模式                                                                                                                                                             | R/W | 0x0   |
| 10     | SHDWDBREDMODE | <b>RED死区加载模式</b><br>0x0: 立即模式<br>0x1: 影子模式                                                                                                                                                             | R/W | 0x0   |
| 9-8    | LOADFEDMODE   | <b>DBFED加载时刻选择</b><br>0x0: CNT = 0<br>0x1: CNT = PRD<br>0x2: CNT = 0, 或者CNT= PRD<br>0x3: 无效<br>注意: 只在影子模式有效                                                                                            | R/W | 0x0   |
| 7-6    | LOADREDMODE   | <b>DBRED加载时刻选择</b><br>0x0: CNT = 0<br>0x1: CNT = PRD<br>0x2: CNT = 0, 或者CNT= PRD<br>0x3: 无效<br>注意: 只在影子模式有效                                                                                            | R/W | 0x0   |
| 5:4    | IN_MODE       | <b>死区输入控制</b>                                                                                                                                                                                          | RW  | 0x0   |

|     |          |                                                                                                                                                                                 |    |     |
|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |          | 死区的输入的行为来自于 AQ 模块<br>0x0: 死区上升沿和下降沿的输入源都选择 EPWMxA<br>0x1: 死区上升沿的输入源选择 EPWMxB, 死区下降沿的输入源选择 EPWMxA<br>0x2: 死区上升沿的输入源选择 EPWMxA, 死区下降沿的输入源选择 EPWMxB<br>0x3: 死区上升沿和下降沿的输入源都选择 EPWMxA |    |     |
| 3:2 | POLSEL   | <b>死区输出极性选择</b><br>0x0: EPWMxA 和 EPWMxB 保持原来的极性输出<br>0x1: EPWMxA 输出极性翻转, EPWMxB 保持原来极性输出<br>0x2: EPWMxA 保持原来极性输出, EPWMxB 输出极性翻转<br>0x3: EPWMxA 和 EPWMxB 输出极性都翻转                 | RW | 0x0 |
| 1:0 | OUT_MODE | <b>死区输出模式选择</b><br>0x0: 关闭死区功能<br>0x1: 关闭上升沿死区, 打开下降沿死区<br>0x2: 打开上升沿死区, 关闭下降沿死区<br>0x3: 同时打开上升沿和下降沿的死区                                                                         | RW | 0x0 |

#### 16.4.3.13. EPWMX\_DBDELAY

| Bit(s) | Name     | Description                   | R/W | Reset |
|--------|----------|-------------------------------|-----|-------|
| 31:30  | reserved | --                            | -   | -     |
| 29:16  | FED      | <b>下降沿的死区时间配置</b><br>14bit 位宽 | RW  | 0x0   |
| 15:14  | reserved | -                             | -   | -     |
| 13:0   | RED      | <b>上升沿的死区时间配置</b><br>14bit 位宽 | RW  | 0x0   |

#### 16.4.3.14. EPWMX\_ETCTL

| Bit(s) | Name     | Description                                                                                 | R/W | Reset |
|--------|----------|---------------------------------------------------------------------------------------------|-----|-------|
| 31:24  | reserved | -                                                                                           | -   | -     |
| 23:20  | SOCBCNT  | <b>SOCB 触发的次数</b><br>0x0: 没有事件触发<br>0x1: 已经触发 1 次<br>0x2: 已经触发 2 次<br>...<br>0xF: 已经触发 15 次 | RO  | 0x0   |
| 19:16  | SOCBPRD  | <b>SOCB 触发的频次选择</b><br>0x0: 关闭                                                              | RW  | 0x0   |

|       |         |                                                                                                                                                      |    |     |
|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|       |         | 0x1: ETCTL[SOCBCNT] = 0x1 时触发中断信号<br>0x2: ETCTL[SOCBCNT] = 0x2 时触发中断信号<br>...<br>0xF: ETCTL[SOCBCNT] = 0xF 时触发中断信号                                   |    |     |
| 15:12 | SOCACNT | <b>SOCA 触发的次数</b><br>0x0: 没有事件触发<br>0x1: 已经触发 1 次<br>0x2: 已经触发 2 次<br>...<br>0xF: 已经触发 15 次                                                          | RO | 0x0 |
| 11:8  | SOCAPRD | <b>SOCA 触发的频次选择</b><br>0x0: 关闭<br>0x1: ETCTL[SOCACNT] = 0x1 时触发中断信号<br>0x2: ETCTL[SOCACNT] = 0x2 时触发中断信号<br>...<br>0xF: ETCTL[SOCACNT] = 0xF 时触发中断信号 | RW | 0x0 |
| 7:4   | INTCNT  | <b>中断触发的次数</b><br>0x0: 没有事件触发<br>0x1: 已经触发 1 次<br>0x2: 已经触发 2 次<br>...<br>0xF: 已经触发 15 次                                                             | RO | 0x0 |
| 3:0   | INTPRD  | <b>中断触发的频次选择</b><br>0x0: 关闭<br>0x1: ETCTL[INTCNT] = 0x1 时触发中断信号<br>0x2: ETCTL[INTCNT] = 0x2 时触发中断信号<br>...<br>0xF: ETCTL[INTCNT] = 0xF 时触发中断信号       | RW | 0x0 |

#### 16.4.3.15. EPWMx\_ETCTL2

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                                                                                | R/W | Reset |
|--------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:26  | Reserved  | -                                                                                                                                                                                                                                                                                                                          | -   | -     |
| 25:16  | MULTSCSEL | 多点触发信号选择<br>每 1 bit 表示一个信号的使能位，可以多通道使能<br>BIT25: CNT = 0<br>BIT24: CNT = PRD<br>BIT23: CNT 处于递增模式，且 CNT = CMPA<br>BIT22: CNT 处于递减模式，且 CNT = CMPA<br>BIT21: CNT 处于递增模式，且 CNT = CMPB<br>BIT20: CNT 处于递减模式，且 CNT = CMPB<br>BIT19: CNT 处于递增模式，且 CNT = CMPC<br>BIT18: CNT 处于递减模式，且 CNT = CMPC<br>BIT17: CNT 处于递增模式，且 CNT = CMPD | RW  | 0x0   |

|       |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    |     |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|       |          | BIT16: CNT 处于递减模式, 且 CNT = CMPD                                                                                                                                                                                                                                                                                                                                                                                                                  |    |     |
| 15    | Reserved | -                                                                                                                                                                                                                                                                                                                                                                                                                                                | -  | -   |
| 14    | SOCBEN   | <b>SOCB 触发使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                                                                                                                                                                                                           | RW | 0x0 |
| 13:10 | SOCBSEL  | <b>SOCB 触发源选择</b><br>0x0: 无效<br>0x1: CNT = 0<br>0x2: CNT = PRD<br>0x3: 在 up-down 模式下, CNT = 0 或者 CNT = PRD<br>0x4: 在 CNT 处于递增趋势, 且 CNT = CMPA<br>0x5: 在 CNT 处于递减趋势, 且 CNT = CMPA<br>0x6: 在 CNT 处于递增趋势, 且 CNT = CMPB<br>0x7: 在 CNT 处于递减趋势, 且 CNT = CMPB<br>0x8: 在 CNT 处于递增趋势, 且 CNT = CMPC<br>0x9: 在 CNT 处于递减趋势, 且 CNT = CMPC<br>0xA: 在 CNT 处于递增趋势, 且 CNT = CMPD<br>0xB: 在 CNT 处于递减趋势, 且 CNT = CMPD<br>0xC: 多点触发信号 ETCTL2[MULTSCSEL]<br>Other: 无效 | RW | 0x0 |
| 9     | SOCAREN  | <b>Soca 触发使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                                                                                                                                                                                                           | RW | 0x0 |
| 8:5   | SOCASEL  | <b>Soca 触发源选择</b><br>0x0: 无效<br>0x1: CNT = 0<br>0x2: CNT = PRD<br>0x3: 在 up-down 模式下, CNT = 0 或者 CNT = PRD<br>0x4: 在 CNT 处于递增趋势, 且 CNT = CMPA<br>0x5: 在 CNT 处于递减趋势, 且 CNT = CMPA<br>0x6: 在 CNT 处于递增趋势, 且 CNT = CMPB<br>0x7: 在 CNT 处于递减趋势, 且 CNT = CMPB<br>0x8: 在 CNT 处于递增趋势, 且 CNT = CMPC<br>0x9: 在 CNT 处于递减趋势, 且 CNT = CMPC<br>0xA: 在 CNT 处于递增趋势, 且 CNT = CMPD<br>0xB: 在 CNT 处于递减趋势, 且 CNT = CMPD<br>0xC: 多点触发信号 ETCTL2[MULTSCSEL]<br>Other: 无效 | RW | 0x0 |
| 4     | INTEN    | <b>中断触发使能</b><br>0x0: 关闭<br>0x1: 打开                                                                                                                                                                                                                                                                                                                                                                                                              | RW | 0x0 |
| 3:0   | INTSEL   | <b>中断触发源选择</b><br>0x0: 无效<br>0x1: CNT = 0<br>0x2: CNT = PRD<br>0x3: 在 up-down 模式下, CNT = 0 或者 CNT = PRD                                                                                                                                                                                                                                                                                                                                          | RW | 0x0 |

|  |  |                                                                                                                                                                                                                                                                                                                                    |  |  |
|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|  |  | 0x4: 在 CNT 处于递增趋势, 且 CNT = CMPA<br>0x5: 在 CNT 处于递减趋势, 且 CNT = CMPA<br>0x6: 在 CNT 处于递增趋势, 且 CNT = CMPB<br>0x7: 在 CNT 处于递减趋势, 且 CNT = CMPB<br>0x8: 在 CNT 处于递增趋势, 且 CNT = CMPC<br>0x9: 在 CNT 处于递减趋势, 且 CNT = CMPC<br>0xA: 在 CNT 处于递增趋势, 且 CNT = CMPD<br>0xB: 在 CNT 处于递减趋势, 且 CNT = CMPD<br>0xC: 多点触发信号 ETCTL2[MULTSCSEL]<br>Other: 无效 |  |  |
|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|

#### 16.4.3.16. EPWMx\_ETFLAG

| Bit(s) | Name     | Description                                         | R/W | Reset |
|--------|----------|-----------------------------------------------------|-----|-------|
| 31:12  | reserved | -                                                   | -   | -     |
| 11     | FRCSOCB  | <b>软件强制 SOCB 触发使能</b><br>0x0: 无效<br>0x1: 产生 SOCB 信号 | RW  | 0x0   |
| 10     | FRCSCOA  | <b>软件强制 SOCA 触发使能</b><br>0x0: 无效<br>0x1: 产生 SOCA 信号 | RW  | 0x0   |
| 9      | Reserved | -                                                   | -   | -     |
| 8      | FRCINT   | <b>软件强制中断触发使能</b><br>0x0: 无效<br>0x1: 产生中断           | RW  | 0x0   |
| 7      | CLRSOCB  | <b>SOCB 触发清除标志</b><br>写 1 清除                        | RW  | 0x0   |
| 6      | CLRSOCA  | <b>SOCB 触发清除标志</b><br>写 1 清除                        | RW  | 0x0   |
| 5      | Reserved | -                                                   | -   | -     |
| 4      | CLRINT   | <b>中断触发清除标志</b><br>写 1 清除                           | RW  | 0x0   |
| 3      | SOCB     | <b>SOCB 触发标志位</b><br>0x0: 未触发<br>0x1: 已经触发          | R   | 0x0   |
| 2      | SOCA     | <b>SOCB 触发标志位</b><br>0x0: 未触发<br>0x1: 已经触发          | RW  | 0x0   |
| 1      | reserved |                                                     | -   | -     |
| 0      | INT      | <b>中断触发标志位</b><br>0x0: 未触发<br>0x1: 已经触发             | RW  | 0x0   |

#### 16.4.3.17. EPWMx\_DCCTL

| Bit(s) | Name            | Description                                                                 | R/W | Reset |
|--------|-----------------|-----------------------------------------------------------------------------|-----|-------|
| 31:20  | reserved        | -                                                                           | -   | -     |
| 19     | AEVT2FRCSYNCSEL | <b>DCAEVT2 强制同步信号选择</b><br>0x0: 同步信号<br>0x1: 异步信号                           | RW  | 0x0   |
| 18     | AEVT2SRCSEL     | <b>DCAEVT2 信号源选择</b><br>0x0: DCAEVT2 Signal<br>0x1: DCEVTFILT Signal        | RW  | 0x0   |
| 17     | AEVT1SYNCE      | <b>DCAEVT1 同步信号使能</b><br>0x0: 关闭<br>0x1: 打开                                 | RW  | 0x0   |
| 16     | AEVT1SOCE       | <b>DCAEVT1 SOC 使能</b><br>0x0: 关闭<br>0x1: 打开                                 | RW  | 0x0   |
| 15     | AEVT1FRCSYNCSEL | <b>DCAEVT1 强制同步信号选择</b><br>0x0: 同步信号<br>0x1: 异步信号                           | RW  | 0x0   |
| 14     | AEVT1SRCSEL     | <b>DCAEVT1 信号源选择</b><br>0x0: DCAEVT1 Signal<br>0x1: DCEVTFILT Signal        | RW  | 0x0   |
| 13     | BEVT2FRCSYNCSEL | <b>DCBEVT2 强制同步信号选择</b><br>0x0: 同步信号<br>0x1: 异步信号                           | RW  | 0x0   |
| 12     | BEVT2SRCSEL     | <b>DCBEVT2 信号源选择</b><br>0x0: DCBEVT2 Signal<br>0x1: DCEVTFILT Signal        | RW  | 0x0   |
| 11     | BEVT1SYNCE      | <b>DCBEVT1 同步信号使能</b><br>0x0: 关闭<br>0x1: 打开                                 | RW  | 0x0   |
| 10     | BEVT1SOCE       | <b>DCBEVT1 SOC 使能</b><br>0x0: 关闭<br>0x1: 打开                                 | RW  | 0x0   |
| 9      | BEVT1FRCSYNCSEL | <b>DCBEVT1 强制同步信号选择</b><br>0x0: 同步信号<br>0x1: 异步信号                           | RW  | 0x0   |
| 8      | BEVT1SRCSEL     | <b>DCBEVT1 信号源选择</b><br>0x0: DCBEVT1 Signal<br>0x1: DCEVTFILT Signal        | RW  | 0x0   |
| 7:6    | PULSESEL        | <b>Blanking 脉冲选择和捕获起始对齐点</b><br>0x0: CNT = PRD<br>0x1: CNT = 0<br>Other: 无效 | RO  | 0x0   |
| 5      | BLANKINV        | <b>Blanking 窗口取反使能</b><br>0x0: 关闭                                           | RW  | 0x0   |

|     |            |                                                                                                                        |    |     |
|-----|------------|------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |            | 0x1: 打开                                                                                                                |    |     |
| 4   | BLANKE     | <b>Blanking 窗口使能</b><br>0x0: 关闭<br>0x1: 打开                                                                             | RW | 0x0 |
| 3:2 | FILTSRCSEL | <b>滤波信号源选择</b><br>0x0: 选择 DCAEVT1 Signal<br>0x1: 选择 DCAEVT2 Signal<br>0x2: 选择 DCBEVT1 Signal<br>0x3: 选择 DCBEVT2 Signal | RW | 0x0 |
| 1   | SHDWMODE   | <b>Capture 影子功能</b><br>0x0: 影子模式<br>0x1: 立即模式                                                                          | RW | 0x0 |
| 0   | CAPE       | <b>Capture 功能使能</b><br>0x0: 关闭<br>0x1: 打开                                                                              | RW | 0x0 |

#### 16.4.3.18. EPWMx\_DCTRIPSEL

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                   | R/W | Reset |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:28  | reserved | -                                                                                                                                                                                                                                                                                             | -   | -     |
| 27:25  | DCBEVT2  | <b>DCB EVT2 输入触发条件选择</b><br>0x0: 关闭<br>0x1: DCBH = low, DCBL = don't care<br>0x2: DCBH = high, DCBL = don't care<br>0x3: DCBL = low, DCBH = don't care<br>0x4: DCBL = high, DCBH = don't care<br>0x5: DCBL = high, DCBH = low<br>0x6: DCBL = high, DCBH = high<br>0x7: DCBL = low, DCBH = low | RW  | 0x0   |
| 24:22  | DCBEVT1  | <b>DCB EVT1 输入触发条件选择</b><br>0x0: 关闭<br>0x1: DCBH = low, DCBL = don't care<br>0x2: DCBH = high, DCBL = don't care<br>0x3: DCBL = low, DCBH = don't care<br>0x4: DCBL = high, DCBH = don't care<br>0x5: DCBL = high, DCBH = low<br>0x6: DCBL = high, DCBH = high<br>0x7: DCBL = low, DCBH = low | RW  | 0x0   |
| 21:19  | DCAEVT2  | <b>DCA EVT2 输入触发条件选择</b><br>0x0: 关闭<br>0x1: DCAH = low, DCAL = don't care<br>0x2: DCAH = high, DCAL = don't care<br>0x3: DCAL = low, DCAH = don't care<br>0x4: DCAL = high, DCAH = don't care<br>0x5: DCAL = high, DCAH = low                                                                 | RW  | 0x0   |

|       |             |                                                                                                                                                                                                                                                                                               |    |     |
|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|       |             | 0x6: DCAL = high, DCAH = high<br>0x7: DCAL = low, DCAH = low                                                                                                                                                                                                                                  |    |     |
| 18:16 | DCAEVT1     | <b>DCA EVT1 输入触发条件选择</b><br>0x0: 关闭<br>0x1: DCAH = low, DCAL = don't care<br>0x2: DCAH = high, DCAL = don't care<br>0x3: DCAL = low, DCAH = don't care<br>0x4: DCAL = high, DCAH = don't care<br>0x5: DCAL = high, DCAH = low<br>0x6: DCAL = high, DCAH = high<br>0x7: DCAL = low, DCAH = low | RW | 0x0 |
| 15:12 | DCBLCOMPSEL | <b>DCBL 输入源选择</b><br>DCBL (Digital Compare B Low Input) 是 DC<br>输入源的 L 端<br>0x0: TZ1 input<br>0x1: TZ2 input<br>0x2: TZ3 input<br>0x3: TZ4 input<br>0x8: COMP1OUT input<br>0x9: COMP2OUT input<br>0xA: COMP3OUT input<br>0xB: COMP4OUT input<br>0xC: COMP5OUT input                           | RW | 0x0 |
| 11:8  | DCBHCOMPSEL | <b>DCBH 输入源选择</b><br>DCBH (Digital Compare B High Input) 是 DC<br>输入源的 H 端<br>0x0: TZ1 input<br>0x1: TZ2 input<br>0x2: TZ3 input<br>0x3: TZ4 input<br>0x8: COMP1OUT input<br>0x9: COMP2OUT input<br>0xA: COMP3OUT input<br>0xB: COMP4OUT input<br>0xC: COMP5OUT input                          | RW | 0x0 |
| 7:4   | DCALCOMPSEL | <b>DCAL 输入源选择</b><br>DCAL (Digital Compare A Low Input) 是 DC<br>输入源的 L 端<br>0x0: TZ1 input<br>0x1: TZ2 input<br>0x2: TZ3 input<br>0x3: TZ4 input<br>0x8: COMP1OUT input<br>0x9: COMP2OUT input<br>0xA: COMP3OUT input<br>0xB: COMP4OUT input                                                  | RW | 0x0 |

|     |             |                                                                                                                                                                                                                                                                   |    |     |
|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|     |             | 0xC: COMP5OUT input                                                                                                                                                                                                                                               |    |     |
| 3:0 | DCAHCOMPSEL | <b>DCAH 输入源选择</b><br>DCAH (Digital Compare A High Input) 是 DC 输入源的 H 端<br>0x0: TZ1 input<br>0x1: TZ2 input<br>0x2: TZ3 input<br>0x3: TZ4 input<br>0x8: COMP1OUT input<br>0x9: COMP2OUT input<br>0xA: COMP3OUT input<br>0xB: COMP4OUT input<br>0xC: COMP5OUT input | RW | 0x0 |

#### 16.4.3.19. EPWMx\_BLANKOFFSET

| Bit(s) | Name     | Description                                                                   | R/W | Reset |
|--------|----------|-------------------------------------------------------------------------------|-----|-------|
| 31:16  | reserved | -                                                                             | -   | -     |
| 15:0   | OFFSET   | <b>Blanking 窗口偏移量</b><br>配置 Blanking 窗口从起始到有效作用的偏移时间，起始点由 DCTRL[PULSESEL] 决定。 | RW  | 0x0   |

#### 16.4.3.20. EPWMx\_WINWIDTH

| Bit(s) | Name     | Description                                                                       | R/W | Reset |
|--------|----------|-----------------------------------------------------------------------------------|-----|-------|
| 31:12  | reserved | -                                                                                 | -   | -     |
| 11:0   | WINDOW   | <b>Blanking 窗口的长度</b><br>0x0: Blanking 窗口不起作用<br>Other: Blanking 生效，单位为 TBCLK 的时间 | RW  | 0x0   |

#### 16.4.3.21. EPWMx\_TZCTL

| Bit(s) | Name          | Description                                                      | R/W | Reset |
|--------|---------------|------------------------------------------------------------------|-----|-------|
| 31     | DCBEVT1_OSTEN | <b>DCB EVT1 OSHT (one-shot-trip) 使能</b><br>0x0: 关闭<br>0x1: 打开    | 0x0 | RW    |
| 30     | DCAEVT1_OSTEN | <b>DCA EVT1 OSHT (one-shot-trip) 使能</b><br>0x0: 关闭<br>0x1: 打开    | 0x0 | RW    |
| 29     | OSHT6         | <b>Trip-zone 6 OSHT (one-shot-trip) 使能</b><br>0x0: 关闭<br>0x1: 打开 | 0x0 | RW    |
| 28     | OSHT5         | <b>Trip-zone 5 OSHT (one-shot-trip) 使能</b>                       | 0x0 | RW    |

|       |               |                                                                                                       |     |    |
|-------|---------------|-------------------------------------------------------------------------------------------------------|-----|----|
|       |               | 0x0: 关闭<br>0x1: 打开                                                                                    |     |    |
| 27    | OSHT4         | Trip-zone 4 OSHT (one-shot-trip) 使能<br>0x0: 关闭<br>0x1: 打开                                             | 0x0 | RW |
| 26    | OSHT3         | Trip-zone 3 OSHT (one-shot-trip) 使能<br>0x0: 关闭<br>0x1: 打开                                             | 0x0 | RW |
| 25    | OSHT2         | Trip-zone 2 OSHT (one-shot-trip) 使能<br>0x0: 关闭<br>0x1: 打开                                             | 0x0 | RW |
| 24    | OSHT1         | Trip-zone 1 OSHT (one-shot-trip) 使能<br>0x0: 关闭<br>0x1: 打开                                             | 0x0 | RW |
| 23    | DCBEVT2_CBCEN | DCB EVT2 CBC (cycle by cycle) 使能<br>0x0: 关闭<br>0x1: 打开                                                | 0x0 | RW |
| 22    | DCAEVT2_CBCEN | DCA EVT2 CBC (cycle by cycle) 使能<br>0x0: 关闭<br>0x1: 打开                                                | 0x0 | RW |
| 21    | CBC6          | Trip-zone 6 CBC (cycle by cycle) 使能<br>0x0: 关闭<br>0x1: 打开                                             | 0x0 | RW |
| 20    | CBC5          | Trip-zone 5 CBC (cycle by cycle) 使能<br>0x0: 关闭<br>0x1: 打开                                             | 0x0 | RW |
| 19    | CBC4          | Trip-zone 4 CBC (cycle by cycle) 使能<br>0x0: 关闭<br>0x1: 打开                                             | 0x0 | RW |
| 18    | CBC3          | Trip-zone 3 CBC (cycle by cycle) 使能<br>0x0: 关闭<br>0x1: 打开                                             | 0x0 | RW |
| 17    | CBC2          | Trip-zone 2 CBC (cycle by cycle) 使能<br>0x0: 关闭<br>0x1: 打开                                             | 0x0 | RW |
| 16    | CBC1          | Trip-zone 1 CBC (cycle by cycle) 使能<br>0x0: 关闭<br>0x1: 打开                                             | 0x0 | RW |
| 15:12 | reserved      | -                                                                                                     | -   | -  |
| 11:10 | DCBEVT2_FRCEN | DCB EVT2 软件触发行为<br>0x0: EPWMxB 输出高阻态<br>0x1: EPWMxB 输出高电平<br>0x2: EPWMxB 输出低电平<br>0x3: EPWMxB 保持原来的状态 | 0x0 | RW |
| 9:8   | DCAEVT2_FRCEN | DCA EVT2 软件触发行为                                                                                       | 0x0 | RW |

|     |               |                                                                                                                    |     |    |
|-----|---------------|--------------------------------------------------------------------------------------------------------------------|-----|----|
|     |               | 0x0: EPWMxA 输出高阻态<br>0x1: EPWMxA 输出高电平<br>0x2: EPWMxA 输出低电平<br>0x3: EPWMxA 保持原来的状态                                 |     |    |
| 7:6 | DCBEVT1_FRCEN | DCB EVT1 软件触发行为<br>0x0: EPWMxB 输出高阻态<br>0x1: EPWMxB 输出高电平<br>0x2: EPWMxB 输出低电平<br>0x3: EPWMxB 保持原来的状态              | 0x0 | RW |
| 5:4 | DCAEVT1_FRCEN | DCA EVT1 软件触发行为<br>0x0: EPWMxA 输出高阻态<br>0x1: EPWMxA 输出高电平<br>0x2: EPWMxA 输出低电平<br>0x3: EPWMxA 保持原来的状态              | 0x0 | RW |
| 3:2 | TZB           | 当 trip-zone 触发时, EPWMxB 行为设置<br>0x0: EPWMxB 输出高阻态<br>0x1: EPWMxB 输出高电平<br>0x2: EPWMxB 输出低电平<br>0x3: EPWMxB 保持原来的状态 | 0x0 | RW |
| 1:0 | TZA           | 当 trip-zone 触发时, EPWMxA 行为设置<br>0x0: EPWMxA 输出高阻态<br>0x1: EPWMxA 输出高电平<br>0x2: EPWMxA 输出低电平<br>0x3: EPWMxA 保持原来的状态 | 0x0 | RW |

#### 16.4.3.22. EPWMx\_TZFLAG

| Bit(s) | Name        | Description                                    | R/W | Reset |
|--------|-------------|------------------------------------------------|-----|-------|
| 31     | reserved    | -                                              | -   | -     |
| 30     | DCBEVT2INTE | DCB EVT2 中断使能<br>0x0: 关闭<br>0x1: 打开            | RW  | 0x0   |
| 29     | DCBEVT1INTE | DCB EVT1 中断使能<br>0x0: 关闭<br>0x1: 打开            | RW  | 0x0   |
| 28     | DCAEVT2INTE | DCA EVT2 中断使能<br>0x0: 关闭<br>0x1: 打开            | RW  | 0x0   |
| 27     | DCAEVT1INTE | DCA EVT1 中断使能<br>0x0: 关闭<br>0x1: 打开            | RW  | 0x0   |
| 26     | OSTINTE     | One-Shot Trip Event 中断使能<br>0x0: 关闭<br>0x1: 打开 | RW  | 0x0   |
| 25     | CBCINTE     | Cycle-by-Cycle Trip Event 中断使能                 | RW  | 0x0   |

|       |              |                                                                        |    |     |
|-------|--------------|------------------------------------------------------------------------|----|-----|
|       |              | 0x0: 关闭<br>0x1: 打开                                                     |    |     |
| 24:23 | reserved     | -                                                                      | -  | -   |
| 22    | CLRDCBEVT2   | <b>DCB EVT2 标志位清除</b><br>写 1 清除标志位                                     | WO | 0x0 |
| 21    | CLRDCBEVT1   | <b>DCB EVT1 标志位清除</b><br>写 1 清除标志位                                     | WO | 0x0 |
| 20    | CLRDCAEV2    | <b>DCA EVT2 标志位清除</b><br>写 1 清除标志位                                     | WO | 0x0 |
| 19    | CLRDCAEV1    | <b>DCA EVT1 标志位清除</b><br>写 1 清除标志位                                     | WO | 0x0 |
| 18    | CLROST       | <b>One-Shot Trip Event 标志清除</b><br>写 1 清除标志位                           | WO | 0x0 |
| 17    | CLRCBC       | <b>Cycle-by-Cycle Trip Event 标志位清除</b><br>写 1 清除标志位                    | WO | 0x0 |
| 16    | CLRINT       | <b>中断标志清除</b><br>写 1 清除标志位                                             | WO | 0x0 |
| 15    | reserved     | -                                                                      | -  | -   |
| 14    | FRCDCBEVT2   | <b>软件强制使能 Digital Compare Output B Event 2</b><br>0x0: 关闭<br>0x1: 打开   | WO | 0x0 |
| 13    | FRCDCBEVT1   | <b>软件强制使能 Digital Compare Output B Event 1</b><br>0x0: 关闭<br>0x1: 打开   | WO | 0x0 |
| 12    | FRCDCAEVT2   | <b>软件强制使能 Digital Compare Output A Event 2</b><br>0x0: 关闭<br>0x1: 打开   | WO | 0x0 |
| 11    | FRCDCAEVT1   | <b>软件强制使能 Digital Compare Output A Event 1</b><br>0x0: 关闭<br>0x1: 打开   | WO | 0x0 |
| 10    | FRCOST       | <b>软件强制使能 One-Shot Trip Event</b><br>0x0: 关闭<br>0x1: 打开                | WO | 0x0 |
| 9     | FRCCBC       | <b>软件强制使能 Cycle-by-Cycle Trip Event</b><br>0x0: 关闭<br>0x1: 打开          | WO | 0x0 |
| 8:7   | reserved     | -                                                                      | -  | -   |
| 6     | DCBEVT2_FLAG | <b>Digital Compare Output B Event 2 标志位</b><br>0x0: 没有触发<br>0x1: 有信号触发 | RW | 0x0 |
| 5     | DCBEVT1_FLAG | <b>Digital Compare Output B Event 1 标志位</b>                            | RW | 0x0 |

|   |              |                                                                        |    |     |
|---|--------------|------------------------------------------------------------------------|----|-----|
|   |              | 0x0: 没有触发<br>0x1: 有信号触发                                                |    |     |
| 4 | DCAEVT2_FLAG | <b>Digital Compare Output A Event 2 标志位</b><br>0x0: 没有触发<br>0x1: 有信号触发 | RW | 0x0 |
| 3 | DCAEVT1_FLAG | <b>Digital Compare Output A Event 1 标志位</b><br>0x0: 没有触发<br>0x1: 有信号触发 | RW | 0x0 |
| 2 | OST          | <b>One-Shot Trip 状态标志位</b><br>0x0: 没有触发<br>0x1: 有信号触发                  | RW | 0x0 |
| 1 | CBC          | <b>Cycle-By-Cycle Trip Event 状态标志位</b><br>0x0: 没有触发<br>0x1: 有信号触发      | RW | 0x0 |
| 0 | INT          | <b>TZ 中断的标志位</b><br>0x0: 没有中断触发<br>0x1: 有中断触发                          | RW | 0x0 |

#### 16.4.3.23. EPWMx\_DCCAP

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                             | R/W | Reset |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | reserved | -                                                                                                                                                                                                                                                                                                       | -   |       |
| 15:0   | DCCAP    | <b>DC 模块捕获的数值</b><br>使能 DCCTL[CAPE] 后，捕获的数据值会存在该寄存器中 <ul style="list-style-type: none"> <li>● 如果 DCCTL[SHDWMODE] = 0，则启用影子模式。在这种模式下，寄存器被复制到由 dcctl [PULSESEL] 位定义的 TBCTR = TBPRD 或 TBCTR = 0 上的影子寄存器。CPU 读取此寄存器将返回影子寄存器值。</li> <li>● 如果 DCCTL[SHDWMODE] = 1，则影子寄存器被禁用。在这种模式下，cpu 读取时将返回寄存器值。</li> </ul> | RW  | 0x0   |

#### 16.4.3.24. EPWM\_TTCTL

| Bit(s) | Name        | Description                                  | R/W | Reset |
|--------|-------------|----------------------------------------------|-----|-------|
| 31:24  | reserved    | -                                            | -   | -     |
| 23     | LVDERR      | <b>LVD error 标志位</b>                         | RO  | 0x0   |
| 22     | WDTERR      | <b>Watchdog error 标志位</b>                    | RO  | 0x0   |
| 21     | HOCERR      | <b>HighspeedOSC error 标志位</b>                | RO  | 0x0   |
| 20     | SYSERR      | <b>System error 标志位</b>                      | RO  | 0x0   |
| 19     | LVDERR_TZEN | <b>LVD error to TripZone 5 使能</b><br>0x0: 关闭 | RW  | 0x0   |

|     |             |                                                                                   |    |     |
|-----|-------------|-----------------------------------------------------------------------------------|----|-----|
|     |             | 0x1: 打开                                                                           |    |     |
| 18  | WDTERR_TZEN | <b>Watchdog error to TripZone 5 使能</b><br>0x0: 关闭<br>0x1: 打开                      | RW | 0x0 |
| 17  | HOCERR_TZEN | <b>Highspeed OSC error to TripZone 5 使能</b><br>0x0: 关闭<br>0x1: 打开                 | RW | 0x0 |
| 16  | SYSERR_TZEN | <b>System error to Tripzone 5 使能</b><br>0x0: 关闭<br>0x1: 打开                        | RW | 0x0 |
| 15  | EPWM3_TZINT | <b>EPWM3 Trip zone 标志位</b>                                                        | R  | 0x0 |
| 14  | EPWM2_TZINT | <b>EPWM2 Trip zone 标志位</b>                                                        | R  | 0x0 |
| 13  | EPWM1_TZINT | <b>EPWM1 Trip zone 标志位</b>                                                        | R  | 0x0 |
| 12  | EPWMO_TZINT | <b>EPWMO Trip zone 标志位</b>                                                        | R  | 0x0 |
| 11  | EPWM3_ETINT | <b>EPWM3 event triger 标志位</b>                                                     | R  | 0x0 |
| 10  | EPWM2_ETINT | <b>EPWM2 event triger 标志位</b>                                                     | R  | 0x0 |
| 9   | EPWM1_ETINT | <b>EPWM1 event triger 标志位</b>                                                     | R  | 0x0 |
| 8   | EPWMO_ETINT | <b>EPWMO event triger 标志位</b>                                                     | R  | 0x0 |
| 7:5 | reserved    | -                                                                                 | -  | -   |
| 4   | CPUTZ       | <b>软件控制 TZ 数值</b><br>Write 1 will force tz6 to 0.<br>Write 0 will force tz6 to 1. | RW | 0x0 |
| 3   | EPWM3_EN    | <b>EPWM3 使能</b><br>0x0: 关闭<br>0x1: 打开                                             | RW | 0x0 |
| 2   | EPWM2_EN    | <b>EPWM2 使能</b><br>0x0: 关闭<br>0x1: 打开                                             | RW | 0x0 |
| 1   | EPWM1_EN    | <b>EPWM1 使能</b><br>0x0: 关闭<br>0x1: 打开                                             | RW | 0x0 |
| 0   | EPWMO_EN    | <b>EPWMO 使能</b><br>0x0: 关闭<br>0x1: 打开                                             | RW | 0x0 |

## 17. WDT

### 17.1. 简介

Watchdog 工作时钟为 32K。默认定时 2S，可以通过修改分频系数改变喂狗时间。通过

配置寄存器，可以选择当计时溢出时，复位系统或者产生中断。

## 17.2. 寄存器

### 17.2.1. 寄存器基地址

| Name | Base Address | Description |
|------|--------------|-------------|
| WDT  | 0x40001000   | WDT 基地址     |

### 17.2.2. 寄存器列表

| Offset Address | Name    | Description |
|----------------|---------|-------------|
| 0x0000         | WDT_CON | 控制寄存器       |
| 0x0004         | WDT_KEY | 秘钥寄存器       |

### 17.2.3. 寄存器详细说明

#### 17.2.3.1. WDT\_CON

| Bit(s) | Name       | Description                                               | R/W | Reset |
|--------|------------|-----------------------------------------------------------|-----|-------|
| 31:10  | reserved   |                                                           | -   | -     |
| 9      | wake_en    | <b>Wakeup 使能</b><br>0x0: 关闭<br>0x1: 打开                    | RO  | 0x0   |
| 8:7    | reserved   | -                                                         | -   | -     |
| 6      | wdt_pend   | <b>WDT 计数满标志</b><br>WDT_KEY 写 0xaaaa, 清除 wdt_pending;     | RO  | 0x0   |
| 5      | int_enable | <b>中断使能</b><br>0x0: 计数满时复位系统<br>0x1: 计数满时产生中断             | RO  | 0x0   |
| 4      | wdte       | 写 WDT_KEY=0xCCCC, 置位<br>写 WDT_KEY=0xDDDD, 复位              | RW  | 0x1   |
| 3:0    | wdt_psr    | <b>分频系数配置</b><br>每次配置该位域之前必须先写 WDT_KEY=0x5555<br>0x0: 不分频 | RW  | 0x8   |

|  |  |                                                                                                                                                                                                           |  |  |
|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|  |  | 0x1: 2<br>0x2: 4<br>0x3: 8<br>0x4: 16<br>0x5: 32<br>0x6: 64<br>0x7: 128<br>0x8: 256<br>0x9: 512<br>0xA: 1024<br>0xB: 2048<br>0xC: 4096<br>0xD: 8192<br>0xE: 16384<br>0xF: 32768<br>看门狗复位时间=1/32K*256*分频系数 |  |  |
|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|

### 17.2.3.2. WDT\_KEY

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                           | R/W | Reset |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 31:16  | reserved | -                                                                                                                                                                                                                                                                                                     | -   | -     |
| 15:0   | KEY      | KEY[15: 0]: 键值（只写寄存器，读出值为0x0000）(Key value)<br>软件必须以一定的间隔写入0xAAAA，否则，当计数器为0时，看门狗会产生复位。当pending为1的时候，写0xAAAA会清除pending。<br>写入0x5555表示允许访问WDT_PSR<br>写入0xCCCC，启动看门狗工作<br>写入0xDDDD，关闭看门狗<br>写入0xaaaa，清除wdt_pending<br>写入0x55AA，开启中断使能<br>写入0xAA55，关闭中断使能<br>写入0x5A5A，开启wake up使能<br>写入0xA5A5，关闭wake up使能 | RO  | 0x0   |